mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 10:42:39 +01:00
8d411fdc2d
To be able to refer to constant keypaths (e.g. `defvar cplusplus = LangOpts<"CPlusPlus">`) inside `ImpliedByAnyOf`, let's accept strings instead of `Option` instances. This somewhat weakens the guarantees that we're referring to an existing (option) record, but we can still use the option.KeyPath syntax to simulate this. Reviewed By: dexonsmith Differential Revision: https://reviews.llvm.org/D95344
61 lines
2.8 KiB
TableGen
61 lines
2.8 KiB
TableGen
include "llvm/Option/OptParser.td"
|
|
|
|
def OptFlag1 : OptionFlag;
|
|
def OptFlag2 : OptionFlag;
|
|
def OptFlag3 : OptionFlag;
|
|
|
|
def A : Flag<["-"], "A">, HelpText<"The A option">, Flags<[OptFlag1]>;
|
|
def AB : Flag<["-"], "AB">;
|
|
def B : Joined<["-"], "B">, HelpText<"The B option">, MetaVarName<"B">, Flags<[OptFlag2]>;
|
|
def C : Separate<["-"], "C">, HelpText<"The C option">, MetaVarName<"C">, Flags<[OptFlag1]>;
|
|
def SLASH_C : Separate<["/", "-"], "C">, HelpText<"The C option">, MetaVarName<"C">, Flags<[OptFlag3]>;
|
|
def D : CommaJoined<["-"], "D">, HelpText<"The D option">, MetaVarName<"D">;
|
|
def E : MultiArg<["-"], "E", 2>, Flags<[OptFlag1, OptFlag2]>;
|
|
def F : JoinedOrSeparate<["-"], "F">, HelpText<"The F option">, MetaVarName<"F">;
|
|
def G : JoinedAndSeparate<["-"], "G">, HelpText<"The G option">, MetaVarName<"G">;
|
|
|
|
def Ceq : Joined<["-", "--"], "C=">, Alias<C>, Flags<[OptFlag1]>;
|
|
|
|
def H : Flag<["-"], "H">, Flags<[HelpHidden]>;
|
|
|
|
def my_group : OptionGroup<"my group">;
|
|
def I : Flag<["-"], "I">, Alias<H>, Group<my_group>;
|
|
|
|
def J : Flag<["-"], "J">, Alias<B>, AliasArgs<["foo"]>;
|
|
def Joo : Flag<["-"], "Joo">, Alias<B>, AliasArgs<["bar"]>;
|
|
|
|
def K : Flag<["-"], "K">, Alias<B>;
|
|
|
|
def Slurp : Option<["-"], "slurp", KIND_REMAINING_ARGS>;
|
|
|
|
def SlurpJoined : Option<["-"], "slurpjoined", KIND_REMAINING_ARGS_JOINED>;
|
|
|
|
def Blorp : Flag<["-", "--"], "blorp">, HelpText<"The blorp option">, Flags<[OptFlag1]>;
|
|
def Blarn : Flag<["--", "-"], "blarn">, HelpText<"The blarn option">, Flags<[OptFlag1]>;
|
|
def Cramb : Joined<["/"], "cramb:">, HelpText<"The cramb option">, MetaVarName<"CRAMB">, Flags<[OptFlag1]>;
|
|
def Doopf1 : Flag<["-"], "doopf1">, HelpText<"The doopf1 option">, Flags<[OptFlag1]>;
|
|
def Doopf2 : Flag<["-"], "doopf2">, HelpText<"The doopf2 option">, Flags<[OptFlag2]>;
|
|
def Ermgh : Joined<["--"], "ermgh">, HelpText<"The ermgh option">, MetaVarName<"ERMGH">, Flags<[OptFlag1]>;
|
|
def Fjormp : Flag<["--"], "fjormp">, HelpText<"The fjormp option">, Flags<[OptFlag1]>;
|
|
|
|
def Glorrmp_eq : Flag<["--"], "glorrmp=">;
|
|
|
|
def Blurmpq : Flag<["--"], "blurmp">;
|
|
def Blurmpq_eq : Flag<["--"], "blurmp=">;
|
|
|
|
def DashDash : Option<["--"], "", KIND_REMAINING_ARGS>;
|
|
|
|
class XOpts<string base> : KeyPathAndMacro<"X->", base> {}
|
|
|
|
def marshalled_flag_d : Flag<["-"], "marshalled-flag-d">,
|
|
MarshallingInfoFlag<XOpts<"MarshalledFlagD">>;
|
|
def marshalled_flag_c : Flag<["-"], "marshalled-flag-c">,
|
|
MarshallingInfoFlag<XOpts<"MarshalledFlagC">>,
|
|
ImpliedByAnyOf<[marshalled_flag_d.KeyPath], "true">;
|
|
def marshalled_flag_b : Flag<["-"], "marshalled-flag-b">,
|
|
MarshallingInfoFlag<XOpts<"MarshalledFlagB">>,
|
|
ImpliedByAnyOf<[marshalled_flag_d.KeyPath], "true">;
|
|
def marshalled_flag_a : Flag<["-"], "marshalled-flag-a">,
|
|
MarshallingInfoFlag<XOpts<"MarshalledFlagA">>,
|
|
ImpliedByAnyOf<[marshalled_flag_c.KeyPath, marshalled_flag_b.KeyPath]>;
|