diff options
author | Chris Lattner <sabre@nondot.org> | 2003-05-22 20:25:57 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-05-22 20:25:57 +0000 |
commit | b3b729b69b311468025ff1e25b3499fcbd83454a (patch) | |
tree | 4e6eb8d3c7b9f6646abe2ce72241a493e85e2653 /include/Support/CommandLine.h | |
parent | 6c8103f7ddb734d128739a463bcd0667d73c62aa (diff) |
Add support for a new "CommaSeparated" modifier
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6293 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/Support/CommandLine.h')
-rw-r--r-- | include/Support/CommandLine.h | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/include/Support/CommandLine.h b/include/Support/CommandLine.h index 23a1285543..6c7a9fc2ae 100644 --- a/include/Support/CommandLine.h +++ b/include/Support/CommandLine.h @@ -16,7 +16,7 @@ #include <string> #include <vector> #include <utility> -#include <stdarg.h> +#include <cstdarg> #include "boost/type_traits/object_traits.hpp" namespace cl { // Short namespace to make usage concise @@ -50,7 +50,7 @@ enum NumOccurances { // Flags for the number of occurances allowed... }; enum ValueExpected { // Is a value required for the option? - ValueOptional = 0x08, // The value can oppear... or not + ValueOptional = 0x08, // The value can appear... or not ValueRequired = 0x10, // The value is required to appear! ValueDisallowed = 0x18, // A value may not be specified (for flags) ValueMask = 0x18, @@ -86,6 +86,12 @@ enum FormattingFlags { FormattingMask = 0x180, }; +enum MiscFlags { // Miscellaneous flags to adjust argument + CommaSeparated = 0x200, // Should this cl::list split between commas? + MiscMask = 0x200, +}; + + //===----------------------------------------------------------------------===// // Option Base class @@ -137,6 +143,9 @@ public: int OH = Flags & FormattingMask; return OH ? (enum FormattingFlags)OH : getFormattingFlagDefault(); } + inline unsigned getMiscFlags() const { + return Flags & MiscMask; + } // hasArgStr - Return true if the argstr != "" bool hasArgStr() const { return ArgStr[0] != 0; } @@ -163,7 +172,7 @@ public: void setValueExpectedFlag(enum ValueExpected Val) { setFlag(Val, ValueMask); } void setHiddenFlag(enum OptionHidden Val) { setFlag(Val, HiddenMask); } void setFormattingFlag(enum FormattingFlags V) { setFlag(V, FormattingMask); } - + void setMiscFlag(enum MiscFlags M) { setFlag(M, M); } protected: Option() : NumOccurances(0), Flags(0), ArgStr(""), HelpStr(""), ValueStr("") {} @@ -583,6 +592,9 @@ template<> struct applicator<OptionHidden> { template<> struct applicator<FormattingFlags> { static void opt(FormattingFlags FF, Option &O) { O.setFormattingFlag(FF); } }; +template<> struct applicator<MiscFlags> { + static void opt(MiscFlags MF, Option &O) { O.setMiscFlag(MF); } +}; // apply method - Apply a modifier to an option in a type safe way. template<class Mod, class Opt> |