diff options
| author | David S. Miller <davem@davemloft.net> | 2010-01-04 18:33:22 -0500 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-01-04 18:33:22 -0500 |
| commit | 5958eed76ccc8c361f872829bdc4b8c6dc9cd379 (patch) | |
| tree | 8f8dfcced082db674b0ae3ca3af9fdb6dde59dae /lib/parser.c | |
| parent | c7c17c2779075e675cb3c7fe2ecde67e226771fb (diff) | |
| parent | c5974b835a909ff15c3b7e6cf6789b5eb919f419 (diff) | |
Merge branch 'master' of /home/davem/src/GIT/linux-2.6/
Diffstat (limited to 'lib/parser.c')
| -rw-r--r-- | lib/parser.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/lib/parser.c b/lib/parser.c index b00d02059a5f..fb34977246bb 100644 --- a/lib/parser.c +++ b/lib/parser.c | |||
| @@ -56,13 +56,16 @@ static int match_one(char *s, const char *p, substring_t args[]) | |||
| 56 | 56 | ||
| 57 | args[argc].from = s; | 57 | args[argc].from = s; |
| 58 | switch (*p++) { | 58 | switch (*p++) { |
| 59 | case 's': | 59 | case 's': { |
| 60 | if (strlen(s) == 0) | 60 | size_t str_len = strlen(s); |
| 61 | |||
| 62 | if (str_len == 0) | ||
| 61 | return 0; | 63 | return 0; |
| 62 | else if (len == -1 || len > strlen(s)) | 64 | if (len == -1 || len > str_len) |
| 63 | len = strlen(s); | 65 | len = str_len; |
| 64 | args[argc].to = s + len; | 66 | args[argc].to = s + len; |
| 65 | break; | 67 | break; |
| 68 | } | ||
| 66 | case 'd': | 69 | case 'd': |
| 67 | simple_strtol(s, &args[argc].to, 0); | 70 | simple_strtol(s, &args[argc].to, 0); |
| 68 | goto num; | 71 | goto num; |
