From: Chung-Lin Tang Date: Mon, 16 Dec 2013 04:28:24 +0000 (+0000) Subject: opts-common.c (integral_argument): Add support for hexadecimal command option integer... X-Git-Tag: releases/gcc-4.9.0~2065 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=317c1849286a2acdf6e72bc2b0973d52b4ba5202;p=thirdparty%2Fgcc.git opts-common.c (integral_argument): Add support for hexadecimal command option integer arguments. 2013-12-16 Chung-Lin Tang * opts-common.c (integral_argument): Add support for hexadecimal command option integer arguments. Update comments. From-SVN: r206008 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 023a2291bac4..8b61a445cef9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2013-12-16 Chung-Lin Tang + + * opts-common.c (integral_argument): Add support for + hexadecimal command option integer arguments. Update comments. + 2013-12-14 Jan Hubicka PR ipa/59265 diff --git a/gcc/opts-common.c b/gcc/opts-common.c index 9d186a759cb5..161ddf0122c9 100644 --- a/gcc/opts-common.c +++ b/gcc/opts-common.c @@ -147,7 +147,7 @@ find_opt (const char *input, unsigned int lang_mask) return match_wrong_lang; } -/* If ARG is a non-negative integer made up solely of digits, return its +/* If ARG is a non-negative decimal or hexadecimal integer, return its value, otherwise return -1. */ int @@ -161,6 +161,17 @@ integral_argument (const char *arg) if (*p == '\0') return atoi (arg); + /* It wasn't a decimal number - try hexadecimal. */ + if (arg[0] == '0' && (arg[1] == 'x' || arg[1] == 'X')) + { + p = arg + 2; + while (*p && ISXDIGIT (*p)) + p++; + + if (p != arg + 2 && *p == '\0') + return strtol (arg, NULL, 16); + } + return -1; }