Przeglądaj źródła

Shell: Allow empty tokens if enclosed in single or double quotes

Previously the shell parser would discard empty tokens. We now allow
them when they are enclosed in quotes (either '' or "")

This means that a command like _echo ""_ will actually pass an empty
string to /bin/echo in argv[1] now.
Andreas Kling 5 lat temu
rodzic
commit
ed90d39cd7
2 zmienionych plików z 6 dodań i 5 usunięć
  1. 4 4
      Shell/Parser.cpp
  2. 2 1
      Shell/Parser.h

+ 4 - 4
Shell/Parser.cpp

@@ -29,9 +29,9 @@
 #include <unistd.h>
 #include <ctype.h>
 
-void Parser::commit_token()
+void Parser::commit_token(AllowEmptyToken allow_empty)
 {
-    if (m_token.is_empty())
+    if (allow_empty == AllowEmptyToken::No && m_token.is_empty())
         return;
     if (m_state == InRedirectionPath) {
         m_redirections.last().path = String::copy(m_token);
@@ -239,7 +239,7 @@ Vector<Command> Parser::parse()
             break;
         case State::InSingleQuotes:
             if (ch == '\'') {
-                commit_token();
+                commit_token(AllowEmptyToken::Yes);
                 m_state = State::Free;
                 break;
             }
@@ -247,7 +247,7 @@ Vector<Command> Parser::parse()
             break;
         case State::InDoubleQuotes:
             if (ch == '\"') {
-                commit_token();
+                commit_token(AllowEmptyToken::Yes);
                 m_state = State::Free;
                 break;
             }

+ 2 - 1
Shell/Parser.h

@@ -67,7 +67,8 @@ public:
     Vector<Command> parse();
 
 private:
-    void commit_token();
+    enum class AllowEmptyToken { No, Yes };
+    void commit_token(AllowEmptyToken = AllowEmptyToken::No);
     void commit_subcommand();
     void commit_command();
     void do_pipe();