diff options
| author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-03-29 12:41:18 -0300 | 
|---|---|---|
| committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-03-31 08:07:46 -0300 | 
| commit | 8a61c27b1e301bb342758434f23bd7828790dcdf (patch) | |
| tree | e1749fdfee920419eb3da1d6a4f60ec32aec5ef5 /src | |
| parent | 2d28251a6e2850998f475c76a886121554c9b7e9 (diff) | |
| download | rneovim-8a61c27b1e301bb342758434f23bd7828790dcdf.tar.gz rneovim-8a61c27b1e301bb342758434f23bd7828790dcdf.tar.bz2 rneovim-8a61c27b1e301bb342758434f23bd7828790dcdf.zip | |
Extract `shell_count_argc` from `mch_call_shell`
Diffstat (limited to 'src')
| -rw-r--r-- | src/os/shell.c | 36 | ||||
| -rw-r--r-- | src/os/shell.h | 1 | ||||
| -rw-r--r-- | src/os_unix.c | 21 | 
3 files changed, 36 insertions, 22 deletions
| diff --git a/src/os/shell.c b/src/os/shell.c index b2248541b9..51e6d65b5b 100644 --- a/src/os/shell.c +++ b/src/os/shell.c @@ -2,12 +2,14 @@  #include "os/shell.h"  #include "types.h" +#include "vim.h"  #include "ascii.h" +#include "charset.h" -void shell_skip_word(char_u **ptr) +void shell_skip_word(char_u **cmd)  { -  char_u *p = *ptr; +  char_u *p = *cmd;    bool inquote = false;    // Move `p` to the end of shell word by advancing the pointer it while it's @@ -19,5 +21,35 @@ void shell_skip_word(char_u **ptr)      ++p;    } +  *cmd = p; +} + +int shell_count_argc(char_u **ptr) +{ +  int rv = 0; +  char_u *p = *ptr; + +  while (true) { +    rv++; +    shell_skip_word(&p); +    if (*p == NUL) +      break; +    // Move to the next word +    p = skipwhite(p); +  } + +  // Account for multiple args in p_shcf('shellcmdflag' option) +  p = p_shcf; +  while (true) { +    // Same as above, but doesn't need to take quotes into consideration +    p = skiptowhite(p); +    if (*p == NUL) +      break; +    rv++; +    p = skipwhite(p); +  } +    *ptr = p; + +  return rv;  } diff --git a/src/os/shell.h b/src/os/shell.h index 166dd26846..754f27df37 100644 --- a/src/os/shell.h +++ b/src/os/shell.h @@ -6,6 +6,7 @@  #include "types.h"  void shell_skip_word(char_u **ptr); +int shell_count_argc(char_u **ptr);  #endif  // NEOVIM_OS_SHELL_H diff --git a/src/os_unix.c b/src/os_unix.c index 7324f1318b..7a3124130f 100644 --- a/src/os_unix.c +++ b/src/os_unix.c @@ -1723,26 +1723,7 @@ int options;                    /* SHELL_*, see vim.h */    // Count the number of arguments for the shell    p = newcmd; -  argc = 0; -  while (true) { -    ++argc; -    shell_skip_word(&p); -    if (*p == NUL) -      break; -    // Move to the next word -    p = skipwhite(p); -  } - -  // Account for multiple args in p_shcf('shellcmdflag' option) -  p = p_shcf; -  while (true) { -    // Same as above, but doesn't need to take quotes into consideration -    p = skiptowhite(p); -    if (*p == NUL) -      break; -    ++argc; -    p = skipwhite(p); -  } +  argc = shell_count_argc(&p);    // Allocate argv memory    argv = (char **)alloc((unsigned)((argc + 4) * sizeof(char *))); | 
