From ae1257a77b108d1c0202547a06473693ea4492c6 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 23 Jul 2002 00:44:37 +0000 Subject: [PATCH] Change to avoid bug in GCC 3.0.4 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2997 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/Support/CommandLine.h | 7 ++++--- include/llvm/Support/CommandLine.h | 7 ++++--- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/include/Support/CommandLine.h b/include/Support/CommandLine.h index e8a4250a894..9e02a6cf417 100644 --- a/include/Support/CommandLine.h +++ b/include/Support/CommandLine.h @@ -173,6 +173,7 @@ public: // occurances of -ArgStr on the command line. // void addArgument(const char *ArgStr); + void removeArgument(const char *ArgStr); // Return the width of the option tag for printing... virtual unsigned getOptionWidth() const = 0; @@ -255,8 +256,8 @@ LocationClass location(Ty &L) { return LocationClass(L); } //===----------------------------------------------------------------------===// // Enum valued command line option // -#define clEnumVal(ENUMVAL, DESC) #ENUMVAL, ENUMVAL, DESC -#define clEnumValN(ENUMVAL, FLAGNAME, DESC) FLAGNAME, ENUMVAL, DESC +#define clEnumVal(ENUMVAL, DESC) #ENUMVAL, (int)ENUMVAL, DESC +#define clEnumValN(ENUMVAL, FLAGNAME, DESC) FLAGNAME, (int)ENUMVAL, DESC // values - For custom data types, allow specifying a group of values together // as the values that go into the mapping that the option handler uses. Note @@ -278,7 +279,7 @@ public: // Process the varargs portion of the values... while (const char *EnumName = va_arg(ValueArgs, const char *)) { - DataType EnumVal = va_arg(ValueArgs, DataType); + DataType EnumVal = (DataType)va_arg(ValueArgs, int); const char *EnumDesc = va_arg(ValueArgs, const char *); Values.push_back(std::make_pair(EnumName, // Add value to value map std::make_pair(EnumVal, EnumDesc))); diff --git a/include/llvm/Support/CommandLine.h b/include/llvm/Support/CommandLine.h index e8a4250a894..9e02a6cf417 100644 --- a/include/llvm/Support/CommandLine.h +++ b/include/llvm/Support/CommandLine.h @@ -173,6 +173,7 @@ public: // occurances of -ArgStr on the command line. // void addArgument(const char *ArgStr); + void removeArgument(const char *ArgStr); // Return the width of the option tag for printing... virtual unsigned getOptionWidth() const = 0; @@ -255,8 +256,8 @@ LocationClass location(Ty &L) { return LocationClass(L); } //===----------------------------------------------------------------------===// // Enum valued command line option // -#define clEnumVal(ENUMVAL, DESC) #ENUMVAL, ENUMVAL, DESC -#define clEnumValN(ENUMVAL, FLAGNAME, DESC) FLAGNAME, ENUMVAL, DESC +#define clEnumVal(ENUMVAL, DESC) #ENUMVAL, (int)ENUMVAL, DESC +#define clEnumValN(ENUMVAL, FLAGNAME, DESC) FLAGNAME, (int)ENUMVAL, DESC // values - For custom data types, allow specifying a group of values together // as the values that go into the mapping that the option handler uses. Note @@ -278,7 +279,7 @@ public: // Process the varargs portion of the values... while (const char *EnumName = va_arg(ValueArgs, const char *)) { - DataType EnumVal = va_arg(ValueArgs, DataType); + DataType EnumVal = (DataType)va_arg(ValueArgs, int); const char *EnumDesc = va_arg(ValueArgs, const char *); Values.push_back(std::make_pair(EnumName, // Add value to value map std::make_pair(EnumVal, EnumDesc)));