Handle heredocs followed by pipes or redirects
Fixes atom/language-shellscript#134
This commit is contained in:
parent
da10d84aec
commit
53446e0e81
|
@ -160,9 +160,9 @@ wc -l $tmpfile
|
||||||
(program
|
(program
|
||||||
(redirected_statement
|
(redirected_statement
|
||||||
(command (command_name (word)))
|
(command (command_name (word)))
|
||||||
(heredoc_redirect (heredoc_start)))
|
(heredoc_redirect (heredoc_start))
|
||||||
|
(file_redirect (simple_expansion (variable_name))))
|
||||||
(heredoc_body
|
(heredoc_body
|
||||||
(simple_expansion (variable_name))
|
|
||||||
(simple_expansion (variable_name))
|
(simple_expansion (variable_name))
|
||||||
(expansion (variable_name)))
|
(expansion (variable_name)))
|
||||||
(command
|
(command
|
||||||
|
@ -170,6 +170,24 @@ wc -l $tmpfile
|
||||||
(word)
|
(word)
|
||||||
(simple_expansion (variable_name))))
|
(simple_expansion (variable_name))))
|
||||||
|
|
||||||
|
=================================
|
||||||
|
Heredocs with pipes
|
||||||
|
================================
|
||||||
|
|
||||||
|
one <<EOF | grep two
|
||||||
|
three
|
||||||
|
EOF
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
(program
|
||||||
|
(pipeline
|
||||||
|
(redirected_statement
|
||||||
|
(command (command_name (word)))
|
||||||
|
(heredoc_redirect (heredoc_start)))
|
||||||
|
(command (command_name (word)) (word)))
|
||||||
|
(heredoc_body))
|
||||||
|
|
||||||
======================================
|
======================================
|
||||||
Heredocs with escaped expansions
|
Heredocs with escaped expansions
|
||||||
======================================
|
======================================
|
||||||
|
|
|
@ -54,11 +54,11 @@ module.exports = grammar({
|
||||||
_statements: $ => prec(1, seq(
|
_statements: $ => prec(1, seq(
|
||||||
repeat(seq(
|
repeat(seq(
|
||||||
$._statement,
|
$._statement,
|
||||||
optional($.heredoc_body),
|
optional(seq('\n', $.heredoc_body)),
|
||||||
$._terminator
|
$._terminator
|
||||||
)),
|
)),
|
||||||
$._statement,
|
$._statement,
|
||||||
optional($.heredoc_body),
|
optional(seq('\n', $.heredoc_body)),
|
||||||
optional($._terminator)
|
optional($._terminator)
|
||||||
)),
|
)),
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"nodemon": "^1.18.3",
|
"nodemon": "^1.18.3",
|
||||||
"prebuild": "^7.6.1",
|
"prebuild": "^7.6.1",
|
||||||
"tree-sitter-cli": "^0.13.1"
|
"tree-sitter-cli": "^0.14.5"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tree-sitter generate && node-gyp build",
|
"build": "tree-sitter generate && node-gyp build",
|
||||||
|
|
|
@ -32,9 +32,18 @@
|
||||||
{
|
{
|
||||||
"type": "CHOICE",
|
"type": "CHOICE",
|
||||||
"members": [
|
"members": [
|
||||||
|
{
|
||||||
|
"type": "SEQ",
|
||||||
|
"members": [
|
||||||
|
{
|
||||||
|
"type": "STRING",
|
||||||
|
"value": "\n"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "SYMBOL",
|
"type": "SYMBOL",
|
||||||
"name": "heredoc_body"
|
"name": "heredoc_body"
|
||||||
|
}
|
||||||
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "BLANK"
|
"type": "BLANK"
|
||||||
|
@ -55,9 +64,18 @@
|
||||||
{
|
{
|
||||||
"type": "CHOICE",
|
"type": "CHOICE",
|
||||||
"members": [
|
"members": [
|
||||||
|
{
|
||||||
|
"type": "SEQ",
|
||||||
|
"members": [
|
||||||
|
{
|
||||||
|
"type": "STRING",
|
||||||
|
"value": "\n"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "SYMBOL",
|
"type": "SYMBOL",
|
||||||
"name": "heredoc_body"
|
"name": "heredoc_body"
|
||||||
|
}
|
||||||
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "BLANK"
|
"type": "BLANK"
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -13,7 +13,7 @@ extern "C" {
|
||||||
#define ts_builtin_sym_end 0
|
#define ts_builtin_sym_end 0
|
||||||
#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
|
#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
|
||||||
|
|
||||||
#ifndef TREE_SITTER_RUNTIME_H_
|
#ifndef TREE_SITTER_API_H_
|
||||||
typedef uint16_t TSSymbol;
|
typedef uint16_t TSSymbol;
|
||||||
typedef struct TSLanguage TSLanguage;
|
typedef struct TSLanguage TSLanguage;
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue