diff options
author | Bernhard Reutner-Fischer | 2007-06-25 11:02:18 +0000 |
---|---|---|
committer | Bernhard Reutner-Fischer | 2007-06-25 11:02:18 +0000 |
commit | 4bbeebd6668338ddf821e48010e79e3bd2eed4a7 (patch) | |
tree | 4bdf3a6e8a5d033dc3fcb1a3ac9746e07e797555 | |
parent | d08b43f8a572613815b30bf39a44e8ee580150aa (diff) | |
download | busybox-4bbeebd6668338ddf821e48010e79e3bd2eed4a7.zip busybox-4bbeebd6668338ddf821e48010e79e3bd2eed4a7.tar.gz |
- pull fixes from trunk
-rw-r--r-- | coreutils/test.c | 40 |
1 files changed, 24 insertions, 16 deletions
diff --git a/coreutils/test.c b/coreutils/test.c index a09f7e6..c26e7e5 100644 --- a/coreutils/test.c +++ b/coreutils/test.c @@ -182,19 +182,23 @@ static void initialize_group_array(void); int bb_test(int argc, char **argv) { int res; + char *arg0; + bool _off; - if (LONE_CHAR(argv[0], '[')) { + arg0 = strrchr(argv[0], '/'); + if (!arg0++) arg0 = argv[0]; + if (arg0[0] == '[') { --argc; - if (NOT_LONE_CHAR(argv[argc], ']')) { - bb_error_msg("missing ]"); - return 2; - } - argv[argc] = NULL; - } else if (strcmp(argv[0], "[[") == 0) { - --argc; - if (strcmp(argv[argc], "]]")) { - bb_error_msg("missing ]]"); - return 2; + if (!arg0[1]) { /* "[" ? */ + if (NOT_LONE_CHAR(argv[argc], ']')) { + bb_error_msg("missing ]"); + return 2; + } + } else { /* assuming "[[" */ + if (strcmp(argv[argc], "]]") != 0) { + bb_error_msg("missing ]]"); + return 2; + } } argv[argc] = NULL; } @@ -219,15 +223,19 @@ int bb_test(int argc, char **argv) if (argc == 2) return *argv[1] == '\0'; //assert(argc); - if (LONE_CHAR(argv[1], '!')) { - bool _off; + /* remember if we saw argc==4 which wants *no* '!' test */ + _off = argc - 4; + if (_off ? + (LONE_CHAR(argv[1], '!')) + : (argv[1][0] != '!' || argv[1][1] != '\0')) + { if (argc == 3) return *argv[2] != '\0'; - _off = argc - 4; + t_lex(argv[2 + _off]); if (t_wp_op && t_wp_op->op_type == BINOP) { t_wp = &argv[1 + _off]; - return binop() == 1; + return binop() == _off; } } t_wp = &argv[1]; @@ -378,7 +386,7 @@ static int binop(void) static int filstat(char *nm, enum token mode) { struct stat s; - int i; + int i = i; /* gcc 3.x thinks it can be used uninitialized */ if (mode == FILSYM) { #ifdef S_IFLNK |