19#ifndef LLVM_SUPPORT_COMMANDLINE_H
20#define LLVM_SUPPORT_COMMANDLINE_H
38#include <initializer_list>
73 const char *EnvVar =
nullptr,
74 bool LongOptionsUseDoubleDash =
false);
191 : Name(Name), Description(Description) {
215 : Name(Name), Description(Description) {
259 virtual bool handleOccurrence(
unsigned pos,
StringRef ArgName,
262 virtual enum ValueExpected getValueExpectedFlagDefault()
const {
267 virtual void anchor();
296 return Value ? ((
enum ValueExpected)Value) : getValueExpectedFlagDefault();
339 : NumOccurrences(0), Occurrences(OccurrencesFlag), Value(0),
341 FullyInitialized(
false), Position(0), AdditionalVals(0) {
378 size_t FirstLineIndentedBy);
386 size_t FirstLineIndentedBy);
393 bool MultiArg =
false);
435 template <
class Opt>
void apply(Opt &O)
const { O.setInitialValue(
Init); }
442 template <
class Opt>
void apply(Opt &O)
const { O.setInitialValues(
Inits); }
462 template <
class Opt>
void apply(Opt &O)
const { O.setLocation(O,
Loc); }
486 template <
class Opt>
void apply(Opt &O)
const {
488 O.addSubCommand(*
Sub);
491 O.addSubCommand(*SC);
497template <
typename R,
typename Ty>
struct cb {
498 std::function<R(Ty)>
CB;
502 template <
typename Opt>
void apply(Opt &O)
const { O.setCallback(
CB); }
509template <
typename R,
typename C,
typename... Args>
512 using arg_type = std::tuple_element_t<0, std::tuple<Args...>>;
513 static_assert(
sizeof...(Args) == 1,
"callback function must have one and only one parameter");
514 static_assert(std::is_same_v<result_type, void>,
515 "callback return type must be void");
516 static_assert(std::is_lvalue_reference_v<arg_type> &&
517 std::is_const_v<std::remove_reference_t<arg_type>>,
518 "callback arg_type must be a const lvalue reference");
544 virtual void anchor();
551template <
class DataType,
bool isClass>
564 bool compare(
const DataType & )
const {
return false; }
590 assert(Valid &&
"invalid option value");
600 bool compare(
const DataType &V)
const {
return Valid && (Value == V); }
612template <
class DataType>
624template <
class DataType>
655 void anchor()
override;
672 void anchor()
override;
686#define clEnumVal(ENUMVAL, DESC) \
687 llvm::cl::OptionEnumValue { #ENUMVAL, int(ENUMVAL), DESC }
688#define clEnumValN(ENUMVAL, FLAGNAME, DESC) \
689 llvm::cl::OptionEnumValue { FLAGNAME, int(ENUMVAL), DESC }
704 template <
class Opt>
void apply(Opt &O)
const {
705 for (
const auto &
Value : Values)
768 size_t GlobalWidth)
const;
774 template <
class AnyOptionValue>
777 size_t GlobalWidth)
const {
787 if (!
Owner.hasArgStr())
804 if (
Owner.hasArgStr())
856 if (
Owner.hasArgStr())
861 for (
size_t i = 0, e =
Values.size(); i != e; ++i)
862 if (
Values[i].Name == ArgVal) {
863 V =
Values[i].V.getValue();
867 return O.error(
"Cannot find option named '" + ArgVal +
"'!");
878 OptionInfo X(Name,
static_cast<DataType
>(V), HelpStr);
911 size_t getOptionWidth(
const Option &O)
const;
916 void printOptionInfo(
const Option &O,
size_t GlobalWidth)
const;
919 void printOptionNoValue(
const Option &O,
size_t GlobalWidth)
const;
925 virtual void anchor();
929 void printOptionName(
const Option &O,
size_t GlobalWidth)
const;
964 size_t GlobalWidth)
const;
990 size_t GlobalWidth)
const;
1011 size_t GlobalWidth)
const;
1032 size_t GlobalWidth)
const;
1053 size_t GlobalWidth)
const;
1074 size_t GlobalWidth)
const;
1097 size_t GlobalWidth)
const;
1115 unsigned long long &Val);
1121 size_t GlobalWidth)
const;
1142 size_t GlobalWidth)
const;
1163 size_t GlobalWidth)
const;
1188 size_t GlobalWidth)
const;
1204 std::optional<std::string> &
Value) {
1237 size_t GlobalWidth)
const;
1248template <
class ParserClass,
class DT>
1252 P.printOptionDiff(O, OV,
Default, GlobalWidth);
1260 P.printOptionNoValue(O, GlobalWidth);
1269 P.printOptionDiff(O, V,
Default, GlobalWidth);
1275template <
class ParserClass,
class ValDT>
1293 template <
class Opt>
static void opt(
const Mod &M, Opt &O) { M.apply(O); }
1315 O.setNumOccurrencesFlag(
N);
1334 "cl::Grouping can only apply to single character Options.");
1340template <
class Opt,
class Mod,
class... Mods>
1346template <
class Opt,
class Mod>
void apply(Opt *O,
const Mod &M) {
1355template <
class DataType,
bool ExternalStorage,
bool isClass>
1357 DataType *Location =
nullptr;
1360 void check_location()
const {
1361 assert(Location &&
"cl::location(...) not specified for a command "
1362 "line option with external storage, "
1363 "or cl::init specified before cl::location()!!");
1371 return O.error(
"cl::location(x) specified more than once!");
1377 template <
class T>
void setValue(
const T &V,
bool initial =
false) {
1402template <
class DataType>
1407 template <
class T>
void setValue(
const T &V,
bool initial =
false) {
1408 DataType::operator=(V);
1432 template <
class T>
void setValue(
const T &V,
bool initial =
false) {
1451template <
class DataType,
bool ExternalStorage =
false,
1452 class ParserClass = parser<DataType>>
1455 public opt_storage<DataType, ExternalStorage, std::is_class_v<DataType>> {
1458 bool handleOccurrence(
unsigned pos,
StringRef ArgName,
1460 typename ParserClass::parser_data_type Val =
1461 typename ParserClass::parser_data_type();
1462 if (Parser.parse(*
this, ArgName, Arg, Val))
1470 enum ValueExpected getValueExpectedFlagDefault()
const override {
1471 return Parser.getValueExpectedFlagDefault();
1475 return Parser.getExtraOptionNames(OptionNames);
1480 return Parser.getOptionWidth(*
this);
1483 void printOptionInfo(
size_t GlobalWidth)
const override {
1484 Parser.printOptionInfo(*
this, GlobalWidth);
1487 void printOptionValue(
size_t GlobalWidth,
bool Force)
const override {
1495 if constexpr (std::is_assignable_v<DataType &, DataType>) {
1506 Parser.initialize();
1526 this->
getValue() = std::forward<T>(Val);
1531 template <
class... Mods>
1532 explicit opt(
const Mods &... Ms)
1539 std::function<
void(
const typename ParserClass::parser_data_type &)> CB) {
1543 std::function<void(
const typename ParserClass::parser_data_type &)>
Callback =
1544 [](
const typename ParserClass::parser_data_type &) {};
1547#if !(defined(LLVM_ENABLE_LLVM_EXPORT_ANNOTATIONS) && defined(_MSC_VER))
1567 std::vector<OptionValue<DataType>> Default =
1568 std::vector<OptionValue<DataType>>();
1569 bool DefaultAssigned =
false;
1578 return O.error(
"cl::location(x) specified more than once!");
1583 template <
class T>
void addValue(
const T &V,
bool initial =
false) {
1584 assert(Location !=
nullptr &&
1585 "cl::location(...) not specified for a command "
1586 "line option with external storage!");
1587 Location->push_back(V);
1589 Default.push_back(V);
1610 std::vector<DataType> Storage;
1611 std::vector<OptionValue<DataType>> Default;
1612 bool DefaultAssigned =
false;
1615 using iterator =
typename std::vector<DataType>::iterator;
1625 using size_type =
typename std::vector<DataType>::size_type;
1629 bool empty()
const {
return Storage.empty(); }
1631 void push_back(
const DataType &value) { Storage.push_back(value); }
1632 void push_back(DataType &&value) { Storage.push_back(value); }
1634 using reference =
typename std::vector<DataType>::reference;
1646 return Storage.erase(first, last);
1651 return Storage.erase(first, last);
1655 return Storage.insert(pos, value);
1658 return Storage.insert(pos, value);
1662 return Storage.insert(pos, value);
1665 return Storage.insert(pos, value);
1671 operator std::vector<DataType> &() {
return Storage; }
1674 const std::vector<DataType> *
operator&()
const {
return &Storage; }
1676 template <
class T>
void addValue(
const T &V,
bool initial =
false) {
1677 Storage.push_back(V);
1695 class ParserClass = parser<DataType>>
1697 std::vector<unsigned> Positions;
1700 enum ValueExpected getValueExpectedFlagDefault()
const override {
1701 return Parser.getValueExpectedFlagDefault();
1705 return Parser.getExtraOptionNames(OptionNames);
1708 bool handleOccurrence(
unsigned pos,
StringRef ArgName,
1710 typename ParserClass::parser_data_type Val =
1711 typename ParserClass::parser_data_type();
1716 if (Parser.parse(*
this, ArgName, Arg, Val))
1720 Positions.push_back(pos);
1727 return Parser.getOptionWidth(*
this);
1730 void printOptionInfo(
size_t GlobalWidth)
const override {
1731 Parser.printOptionInfo(*
this, GlobalWidth);
1735 void printOptionValue(
size_t ,
bool )
const override {
1747 Parser.initialize();
1758 assert(optnum < this->
size() &&
"Invalid option index");
1759 return Positions[optnum];
1770 "Cannot have two default values");
1772 for (
auto &Val : Vs)
1778 template <
class... Mods>
1786 std::function<
void(
const typename ParserClass::parser_data_type &)> CB) {
1790 std::function<void(
const typename ParserClass::parser_data_type &)>
Callback =
1791 [](
const typename ParserClass::parser_data_type &) {};
1799 template <
typename D,
typename S,
typename P>
1811 unsigned *Location =
nullptr;
1813 template <
class T>
static unsigned Bit(
const T &V) {
1814 unsigned BitPos =
static_cast<unsigned>(V);
1815 assert(BitPos <
sizeof(
unsigned) * CHAR_BIT &&
1816 "enum exceeds width of bit vector!");
1825 return O.error(
"cl::location(x) specified more than once!");
1831 assert(Location !=
nullptr &&
1832 "cl::location(...) not specified for a command "
1833 "line option with external storage!");
1834 *Location |= Bit(V);
1845 return (*Location & Bit(V)) != 0;
1855 template <
class T>
static unsigned Bit(
const T &V) {
1856 unsigned BitPos =
static_cast<unsigned>(V);
1857 assert(BitPos <
sizeof(
unsigned) * CHAR_BIT &&
1858 "enum exceeds width of bit vector!");
1863 template <
class T>
void addValue(
const T &V) { Bits |= Bit(V); }
1869 template <
class T>
bool isSet(
const T &V) {
return (Bits & Bit(V)) != 0; }
1875template <
class DataType,
class Storage =
bool,
1876 class ParserClass = parser<DataType>>
1878 std::vector<unsigned> Positions;
1881 enum ValueExpected getValueExpectedFlagDefault()
const override {
1882 return Parser.getValueExpectedFlagDefault();
1886 return Parser.getExtraOptionNames(OptionNames);
1889 bool handleOccurrence(
unsigned pos,
StringRef ArgName,
1891 typename ParserClass::parser_data_type Val =
1892 typename ParserClass::parser_data_type();
1893 if (Parser.parse(*
this, ArgName, Arg, Val))
1897 Positions.push_back(pos);
1904 return Parser.getOptionWidth(*
this);
1907 void printOptionInfo(
size_t GlobalWidth)
const override {
1908 Parser.printOptionInfo(*
this, GlobalWidth);
1912 void printOptionValue(
size_t ,
bool )
const override {
1919 Parser.initialize();
1930 assert(optnum < this->
size() &&
"Invalid option index");
1931 return Positions[optnum];
1934 template <
class... Mods>
1942 std::function<
void(
const typename ParserClass::parser_data_type &)> CB) {
1946 std::function<void(
const typename ParserClass::parser_data_type &)>
Callback =
1947 [](
const typename ParserClass::parser_data_type &) {};
1957 bool handleOccurrence(
unsigned pos,
StringRef ,
1959 return AliasFor->handleOccurrence(pos, AliasFor->ArgStr, Arg);
1963 bool MultiArg =
false)
override {
1964 return AliasFor->addOccurrence(pos, AliasFor->ArgStr, Value, MultiArg);
1968 size_t getOptionWidth()
const override;
1969 void printOptionInfo(
size_t GlobalWidth)
const override;
1972 void printOptionValue(
size_t ,
bool )
const override {
1975 void setDefault()
override { AliasFor->setDefault(); }
1977 ValueExpected getValueExpectedFlagDefault()
const override {
1978 return AliasFor->getValueExpectedFlag();
1983 error(
"cl::alias must have argument name specified!");
1985 error(
"cl::alias must have an cl::aliasopt(option) specified!");
1987 error(
"cl::alias must not have cl::sub(), aliased option's cl::sub() will be used!");
1988 Subs = AliasFor->Subs;
2000 error(
"cl::alias must only have one cl::aliasopt(...) specified!");
2004 template <
class... Mods>
2123 bool MarkEOLs =
false);
2141 bool MarkEOLs =
false);
2167 bool MarkEOLs =
false);
2186 bool MarkEOLs =
false);
2208 bool RelativeNames =
false;
2212 bool MarkEOLs =
false;
2215 bool InConfigFile =
false;
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the StringMap class.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
#define LLVM_TEMPLATE_ABI
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Lightweight error class with error context and mandatory checking.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
StringRef - Represent a constant reference to a string, i.e.
std::string str() const
str - Get the contents as an std::string.
Saves strings in the provided stable storage and returns a StringRef with a stable character pointer.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
LLVM Value Representation.
LLVM_ABI Value(Type *Ty, unsigned scid)
ExpansionContext & setCurrentDir(StringRef X)
LLVM_ABI ExpansionContext(BumpPtrAllocator &A, TokenizerCallback T, vfs::FileSystem *FS=nullptr)
ExpansionContext & setVFS(vfs::FileSystem *X)
ExpansionContext & setMarkEOLs(bool X)
ExpansionContext & setSearchDirs(ArrayRef< StringRef > X)
ExpansionContext & setRelativeNames(bool X)
LLVM_ABI bool findConfigFile(StringRef FileName, SmallVectorImpl< char > &FilePath)
Looks for the specified configuration file.
LLVM_ABI Error expandResponseFiles(SmallVectorImpl< const char * > &Argv)
Expands constructs "@file" in the provided array of arguments recursively.
LLVM_ABI Error readConfigFile(StringRef CfgFile, SmallVectorImpl< const char * > &Argv)
Reads command line options from the given configuration file.
OptionCategory(StringRef const Name, StringRef const Description="")
StringRef getDescription() const
StringRef getName() const
OptionValueCopy & operator=(const OptionValueCopy &)=default
OptionValueCopy()=default
bool compare(const GenericOptionValue &V) const override
void setValue(const DataType &V)
~OptionValueCopy()=default
const DataType & getValue() const
OptionValueCopy(const OptionValueCopy &)=default
bool compare(const DataType &V) const
bool isPositional() const
virtual void getExtraOptionNames(SmallVectorImpl< StringRef > &)
void setValueExpectedFlag(enum ValueExpected Val)
void setPosition(unsigned pos)
bool isConsumeAfter() const
SmallPtrSet< SubCommand *, 1 > Subs
int getNumOccurrences() const
enum ValueExpected getValueExpectedFlag() const
void setValueStr(StringRef S)
void setNumOccurrencesFlag(enum NumOccurrencesFlag Val)
void setNumAdditionalVals(unsigned n)
void setDescription(StringRef S)
void setFormattingFlag(enum FormattingFlags V)
void setHiddenFlag(enum OptionHidden Val)
void setMiscFlag(enum MiscFlags M)
enum FormattingFlags getFormattingFlag() const
virtual void printOptionInfo(size_t GlobalWidth) const =0
enum NumOccurrencesFlag getNumOccurrencesFlag() const
SmallVector< OptionCategory *, 1 > Categories
void addSubCommand(SubCommand &S)
bool isDefaultOption() const
unsigned getMiscFlags() const
virtual void setDefault()=0
virtual void printOptionValue(size_t GlobalWidth, bool Force) const =0
virtual ~Option()=default
static void printEnumValHelpStr(StringRef HelpStr, size_t Indent, size_t FirstLineIndentedBy)
unsigned getNumAdditionalVals() const
void removeArgument()
Unregisters this option from the CommandLine system.
Option(enum NumOccurrencesFlag OccurrencesFlag, enum OptionHidden Hidden)
enum OptionHidden getOptionHiddenFlag() const
bool error(const Twine &Message, raw_ostream &Errs)
static void printHelpStr(StringRef HelpStr, size_t Indent, size_t FirstLineIndentedBy)
virtual size_t getOptionWidth() const =0
unsigned getPosition() const
SubCommandGroup(std::initializer_list< SubCommand * > IL)
ArrayRef< SubCommand * > getSubCommands() const
StringRef getName() const
SubCommand(StringRef Name, StringRef Description="")
SmallVector< Option *, 4 > SinkOpts
static LLVM_ABI SubCommand & getTopLevel()
LLVM_ABI void unregisterSubCommand()
static LLVM_ABI SubCommand & getAll()
LLVM_ABI void registerSubCommand()
SmallVector< Option *, 4 > PositionalOpts
StringMap< Option * > OptionsMap
StringRef getDescription() const
ValuesClass(std::initializer_list< OptionEnumValue > Options)
alias(const alias &)=delete
void setAliasFor(Option &O)
alias & operator=(const alias &)=delete
alias(const Mods &... Ms)
enum ValueExpected getValueExpectedFlagDefault() const
void getExtraOptionNames(SmallVectorImpl< StringRef > &)
virtual StringRef getValueName() const
virtual ~basic_parser_impl()=default
basic_parser_impl(Option &)
OptionValue< DataType > OptVal
DataType parser_data_type
void addValue(const T &V)
void addValue(const T &V)
bool setLocation(Option &O, unsigned &L)
bits & operator=(const bits &)=delete
ParserClass & getParser()
unsigned getPosition(unsigned optnum) const
void setCallback(std::function< void(const typename ParserClass::parser_data_type &)> CB)
std::function< void(const typename ParserClass::parser_data_type &)> Callback
bits(const bits &)=delete
GenericOptionInfo(StringRef name, StringRef helpStr)
virtual size_t getOptionWidth(const Option &O) const
generic_parser_base(Option &O)
virtual StringRef getDescription(unsigned N) const =0
virtual const GenericOptionValue & getOptionValue(unsigned N) const =0
virtual unsigned getNumOptions() const =0
virtual StringRef getOption(unsigned N) const =0
void printOptionDiff(const Option &O, const AnyOptionValue &V, const AnyOptionValue &Default, size_t GlobalWidth) const
void printGenericOptionDiff(const Option &O, const GenericOptionValue &V, const GenericOptionValue &Default, size_t GlobalWidth) const
virtual void printOptionInfo(const Option &O, size_t GlobalWidth) const
unsigned findOption(StringRef Name)
virtual ~generic_parser_base()=default
void getExtraOptionNames(SmallVectorImpl< StringRef > &OptionNames)
enum ValueExpected getValueExpectedFlagDefault() const
void push_back(DataType &&value)
typename std::vector< DataType >::const_iterator const_iterator
typename std::vector< DataType >::const_reference const_reference
const_iterator begin() const
iterator erase(const_iterator first, const_iterator last)
iterator insert(const_iterator pos, const DataType &value)
iterator erase(iterator first, iterator last)
const_reference operator[](size_type pos) const
void addValue(const T &V, bool initial=false)
void push_back(const DataType &value)
typename std::vector< DataType >::reference reference
reference operator[](size_type pos)
const std::vector< DataType > * operator&() const
iterator insert(iterator pos, const DataType &value)
typename std::vector< DataType >::size_type size_type
const_reference front() const
const_iterator end() const
iterator insert(const_iterator pos, DataType &&value)
iterator erase(iterator pos)
std::vector< DataType > * operator&()
const std::vector< OptionValue< DataType > > & getDefault() const
iterator erase(const_iterator pos)
iterator insert(iterator pos, DataType &&value)
typename std::vector< DataType >::iterator iterator
const std::vector< OptionValue< DataType > > & getDefault() const
void addValue(const T &V, bool initial=false)
bool setLocation(Option &O, StorageClass &L)
void setCallback(std::function< void(const typename ParserClass::parser_data_type &)> CB)
list(const list &)=delete
void setInitialValues(ArrayRef< DataType > Vs)
std::function< void(const typename ParserClass::parser_data_type &)> Callback
list & operator=(const list &)=delete
ParserClass & getParser()
unsigned getPosition(unsigned optnum) const
void setNumAdditionalVals(unsigned n)
OptionValue< DataType > Default
DataType operator->() const
const OptionValue< DataType > & getDefault() const
void setValue(const T &V, bool initial=false)
DataType getValue() const
void setValue(const T &V, bool initial=false)
OptionValue< DataType > Default
const DataType & getValue() const
const OptionValue< DataType > & getDefault() const
const DataType & getValue() const
bool setLocation(Option &O, DataType &L)
void setValue(const T &V, bool initial=false)
const OptionValue< DataType > & getDefault() const
ParserClass & getParser()
opt & operator=(const opt &)=delete
void setInitialValue(const DataType &V)
void setCallback(std::function< void(const typename ParserClass::parser_data_type &)> CB)
DataType & operator=(const T &Val)
DataType & operator=(T &&Val)
std::function< void(const typename ParserClass::parser_data_type &)> Callback
OptionInfo(StringRef name, DataType v, StringRef helpStr)
OptionValue< DataType > V
bool parse(Option &O, StringRef ArgName, StringRef Arg, boolOrDefault &Val)
void printOptionDiff(const Option &O, boolOrDefault V, OptVal Default, size_t GlobalWidth) const
StringRef getValueName() const override
enum ValueExpected getValueExpectedFlagDefault() const
enum ValueExpected getValueExpectedFlagDefault() const
void printOptionDiff(const Option &O, bool V, OptVal Default, size_t GlobalWidth) const
bool parse(Option &O, StringRef ArgName, StringRef Arg, bool &Val)
StringRef getValueName() const override
bool parse(Option &, StringRef, StringRef Arg, char &Value)
void printOptionDiff(const Option &O, char V, OptVal Default, size_t GlobalWidth) const
StringRef getValueName() const override
void printOptionDiff(const Option &O, double V, OptVal Default, size_t GlobalWidth) const
StringRef getValueName() const override
bool parse(Option &O, StringRef ArgName, StringRef Arg, double &Val)
bool parse(Option &O, StringRef ArgName, StringRef Arg, float &Val)
StringRef getValueName() const override
void printOptionDiff(const Option &O, float V, OptVal Default, size_t GlobalWidth) const
StringRef getValueName() const override
void printOptionDiff(const Option &O, int V, OptVal Default, size_t GlobalWidth) const
bool parse(Option &O, StringRef ArgName, StringRef Arg, int &Val)
StringRef getValueName() const override
bool parse(Option &O, StringRef ArgName, StringRef Arg, long &Val)
void printOptionDiff(const Option &O, long V, OptVal Default, size_t GlobalWidth) const
bool parse(Option &O, StringRef ArgName, StringRef Arg, long long &Val)
StringRef getValueName() const override
void printOptionDiff(const Option &O, long long V, OptVal Default, size_t GlobalWidth) const
void printOptionDiff(const Option &O, std::optional< StringRef > V, const OptVal &Default, size_t GlobalWidth) const
bool parse(Option &, StringRef, StringRef Arg, std::optional< std::string > &Value)
StringRef getValueName() const override
StringRef getValueName() const override
void printOptionDiff(const Option &O, StringRef V, const OptVal &Default, size_t GlobalWidth) const
bool parse(Option &, StringRef, StringRef Arg, std::string &Value)
bool parse(Option &O, StringRef ArgName, StringRef Arg, unsigned &Val)
void printOptionDiff(const Option &O, unsigned V, OptVal Default, size_t GlobalWidth) const
StringRef getValueName() const override
StringRef getValueName() const override
void printOptionDiff(const Option &O, unsigned long V, OptVal Default, size_t GlobalWidth) const
bool parse(Option &O, StringRef ArgName, StringRef Arg, unsigned long &Val)
StringRef getValueName() const override
void printOptionDiff(const Option &O, unsigned long long V, OptVal Default, size_t GlobalWidth) const
bool parse(Option &O, StringRef ArgName, StringRef Arg, unsigned long long &Val)
DataType parser_data_type
SmallVector< OptionInfo, 8 > Values
void removeLiteralOption(StringRef Name)
Remove the specified option.
StringRef getDescription(unsigned N) const override
void addLiteralOption(StringRef Name, const DT &V, StringRef HelpStr)
Add an entry to the mapping table.
const GenericOptionValue & getOptionValue(unsigned N) const override
StringRef getOption(unsigned N) const override
bool parse(Option &O, StringRef ArgName, StringRef Arg, DataType &V)
unsigned getNumOptions() const override
A range adaptor for a pair of iterators.
This class implements an extremely fast bulk output stream that can only output to a stream.
The virtual file system interface.
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
This namespace contains all of the command line option processing machinery.
LLVM_ABI void PrintVersionMessage()
Utility function for printing version number.
LLVM_ABI bool ExpandResponseFiles(StringSaver &Saver, TokenizerCallback Tokenizer, SmallVectorImpl< const char * > &Argv)
A convenience helper which supports the typical use case of expansion function call.
LLVM_ABI void TokenizeWindowsCommandLine(StringRef Source, StringSaver &Saver, SmallVectorImpl< const char * > &NewArgv, bool MarkEOLs=false)
Tokenizes a string of Windows command line arguments, which may contain quotes and escaped quotes.
list_initializer< Ty > list_init(ArrayRef< Ty > Vals)
LLVM_ABI OptionCategory & getGeneralCategory()
LLVM_ABI void ResetAllOptionOccurrences()
Reset all command line options to a state that looks as if they have never appeared on the command li...
LLVM_ABI void SetVersionPrinter(VersionPrinterTy func)
===------------------------------------------------------------------—===// Override the default (LLV...
LLVM_ABI void tokenizeConfigFile(StringRef Source, StringSaver &Saver, SmallVectorImpl< const char * > &NewArgv, bool MarkEOLs=false)
Tokenizes content of configuration file.
LLVM_ABI StringMap< Option * > & getRegisteredOptions(SubCommand &Sub=SubCommand::getTopLevel())
Use this to get a StringMap to all registered named options (e.g.
LLVM_ABI void ResetCommandLineParser()
Reset the command line parser back to its initial state.
LLVM_ABI void PrintOptionValues()
LLVM_ABI iterator_range< typename SmallPtrSet< SubCommand *, 4 >::iterator > getRegisteredSubcommands()
Use this to get all registered SubCommands from the provided parser.
void apply(Opt *O, const Mod &M, const Mods &... Ms)
LLVM_ABI void AddLiteralOption(Option &O, StringRef Name)
Adds a new option for parsing and provides the option it refers to.
void printOptionDiff(const Option &O, const generic_parser_base &P, const DT &V, const OptionValue< DT > &Default, size_t GlobalWidth)
LLVM_ABI void TokenizeWindowsCommandLineNoCopy(StringRef Source, StringSaver &Saver, SmallVectorImpl< StringRef > &NewArgv)
Tokenizes a Windows command line while attempting to avoid copies.
ValuesClass values(OptsTy... Options)
Helper to build a ValuesClass by forwarding a variable number of arguments as an initializer list to ...
template class LLVM_TEMPLATE_ABI basic_parser< bool >
LLVM_ABI void printBuildConfig(raw_ostream &OS)
Prints the compiler build configuration.
void(*)(StringRef Source, StringSaver &Saver, SmallVectorImpl< const char * > &NewArgv, bool MarkEOLs) TokenizerCallback
String tokenization function type.
LLVM_ABI bool ProvidePositionalOption(Option *Handler, StringRef Arg, int i)
Parses Arg into the option handler Handler.
LLVM_ABI bool expandResponseFiles(int Argc, const char *const *Argv, const char *EnvVar, SmallVectorImpl< const char * > &NewArgv)
A convenience helper which concatenates the options specified by the environment variable EnvVar and ...
initializer< Ty > init(const Ty &Val)
std::function< void(raw_ostream &)> VersionPrinterTy
LLVM_ABI ArrayRef< StringRef > getCompilerBuildConfig()
An array of optional enabled settings in the LLVM build configuration, which may be of interest to co...
LocationClass< Ty > location(Ty &L)
cb< typename detail::callback_traits< F >::result_type, typename detail::callback_traits< F >::arg_type > callback(F CB)
LLVM_ABI void HideUnrelatedOptions(cl::OptionCategory &Category, SubCommand &Sub=SubCommand::getTopLevel())
Mark all options not part of this category as cl::ReallyHidden.
LLVM_ABI void AddExtraVersionPrinter(VersionPrinterTy func)
===------------------------------------------------------------------—===// Add an extra printer to u...
LLVM_ABI void PrintHelpMessage(bool Hidden=false, bool Categorized=false)
This function just prints the help message, exactly the same way as if the -help or -help-hidden opti...
LLVM_ABI void TokenizeWindowsCommandLineFull(StringRef Source, StringSaver &Saver, SmallVectorImpl< const char * > &NewArgv, bool MarkEOLs=false)
Tokenizes a Windows full command line, including command name at the start.
LLVM_ABI bool ParseCommandLineOptions(int argc, const char *const *argv, StringRef Overview="", raw_ostream *Errs=nullptr, vfs::FileSystem *VFS=nullptr, const char *EnvVar=nullptr, bool LongOptionsUseDoubleDash=false)
LLVM_ABI void TokenizeGNUCommandLine(StringRef Source, StringSaver &Saver, SmallVectorImpl< const char * > &NewArgv, bool MarkEOLs=false)
Tokenizes a command line that can contain escapes and quotes.
This is an optimization pass for GlobalISel generic memory operations.
auto size(R &&Range, std::enable_if_t< std::is_base_of< std::random_access_iterator_tag, typename std::iterator_traits< decltype(Range.begin())>::iterator_category >::value, void > *=nullptr)
Get the size of a range.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
BumpPtrAllocatorImpl BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
@ Mod
The access may modify the value stored in memory.
@ Sub
Subtraction of integers.
ArrayRef(const T &OneElt) -> ArrayRef< T >
@ Default
The result values are uniform if and only if all operands are uniform.
Implement std::hash so that hash_code can be used in STL containers.
GenericOptionValue()=default
GenericOptionValue(const GenericOptionValue &)=default
GenericOptionValue & operator=(const GenericOptionValue &)=default
~GenericOptionValue()=default
virtual bool compare(const GenericOptionValue &V) const =0
void print(const Option &O, const parser< DT > &P, const DT &V, const OptionValue< DT > &Default, size_t GlobalWidth)
void print(const Option &O, const parser< ParserDT > &P, const ValDT &, const OptionValue< ValDT > &, size_t GlobalWidth)
~OptionValueBase()=default
OptionValueBase & operator=(const OptionValueBase &)=default
OptionValueBase(const OptionValueBase &)=default
OptionValueBase()=default
bool compare(const DataType &) const
const DataType & getValue() const
~OptionValueBase()=default
bool compare(const GenericOptionValue &) const override
OptionValue< DataType > WrapperType
void setValue(const DT &)
OptionValue< cl::boolOrDefault > & operator=(const cl::boolOrDefault &V)
OptionValue(const cl::boolOrDefault &V)
cl::boolOrDefault WrapperType
OptionValue< std::string > & operator=(const std::string &V)
OptionValue(const std::string &V)
OptionValue(const DataType &V)
OptionValue< DataType > & operator=(const DT &V)
void apply(alias &A) const
static void opt(MiscFlags MF, Option &O)
static void opt(NumOccurrencesFlag N, Option &O)
static void opt(OptionHidden OH, Option &O)
static void opt(StringRef Str, Opt &O)
static void opt(ValueExpected VE, Option &O)
static void opt(StringRef Str, Opt &O)
static void opt(StringRef Str, Opt &O)
static void opt(const Mod &M, Opt &O)
OptionCategory & Category
cb(std::function< R(Ty)> CB)
void apply(Option &O) const
std::tuple_element_t< 0, std::tuple< Args... > > arg_type
initializer(const Ty &Val)
list_initializer(ArrayRef< Ty > Vals)
void apply(list< D, S, P > &L) const
void apply(Option &O) const
value_desc(StringRef Str)