* strings.c (main): Delay parsing of decimal digits.
authorAlan Modra <amodra@gmail.com>
Thu, 4 Jun 2009 08:27:54 +0000 (08:27 +0000)
committerAlan Modra <amodra@gmail.com>
Thu, 4 Jun 2009 08:27:54 +0000 (08:27 +0000)
binutils/ChangeLog
binutils/strings.c

index 74ff09eee1cb7d02bd83105cffcbacb4a4265384..dc4f09b8b849c4564390be89024cdff951dd4135 100644 (file)
@@ -1,3 +1,7 @@
+2009-06-04  Alan Modra  <amodra@bigpond.net.au>
+
+       * strings.c (main): Delay parsing of decimal digits.
+
 2009-06-04  Alan Modra  <amodra@bigpond.net.au>
 
        * dep-in.sed: Don't use \n in replacement part of s command.
index dc582f56d00ff2866167eecc6f9799e7843ba34e..06fd8e995b72d1f772129b9d3ec8f2d1d79ab70f 100644 (file)
@@ -158,6 +158,7 @@ main (int argc, char **argv)
   int exit_status = 0;
   bfd_boolean files_given = FALSE;
   char *s;
+  int numeric_opt = 0;
 
 #if defined (HAVE_SETLOCALE)
   setlocale (LC_ALL, "");
@@ -247,13 +248,17 @@ main (int argc, char **argv)
          usage (stderr, 1);
 
        default:
-         string_min = (int) strtoul (argv[optind - 1] + 1, &s, 0);
-         if (s != NULL && *s != 0)
-           fatal (_("invalid integer argument %s"), argv[optind - 1] + 1);
+         numeric_opt = optind;
          break;
        }
     }
 
+  if (numeric_opt != 0)
+    {
+      string_min = (int) strtoul (argv[numeric_opt - 1] + 1, &s, 0);
+      if (s != NULL && *s != 0)
+       fatal (_("invalid integer argument %s"), argv[numeric_opt - 1] + 1);
+    }
   if (string_min < 1)
     fatal (_("invalid minimum string length %d"), string_min);