| //===----------------------------------------------------------------------===// |
| // Define command classes. |
| //===----------------------------------------------------------------------===// |
| |
| class Command<string name> { |
| string Name = name; |
| string EndCommandName = ""; |
| |
| int NumArgs = 0; |
| |
| bit IsInlineCommand = 0; |
| |
| bit IsBlockCommand = 0; |
| bit IsBriefCommand = 0; |
| bit IsReturnsCommand = 0; |
| bit IsParamCommand = 0; |
| bit IsTParamCommand = 0; |
| bit IsThrowsCommand = 0; |
| bit IsDeprecatedCommand = 0; |
| bit IsHeaderfileCommand = 0; |
| |
| bit IsEmptyParagraphAllowed = 0; |
| |
| bit IsVerbatimBlockCommand = 0; |
| bit IsVerbatimBlockEndCommand = 0; |
| bit IsVerbatimLineCommand = 0; |
| bit IsDeclarationCommand = 0; |
| bit IsFunctionDeclarationCommand = 0; |
| bit IsRecordLikeDetailCommand = 0; |
| bit IsRecordLikeDeclarationCommand = 0; |
| } |
| |
| class InlineCommand<string name> : Command<name> { |
| let IsInlineCommand = 1; |
| } |
| |
| class BlockCommand<string name> : Command<name> { |
| let IsBlockCommand = 1; |
| } |
| |
| class RecordLikeDetailCommand<string name> : BlockCommand<name> { |
| let IsRecordLikeDetailCommand = 1; |
| } |
| |
| class VerbatimBlockCommand<string name> : Command<name> { |
| let EndCommandName = name; |
| let IsVerbatimBlockCommand = 1; |
| } |
| |
| multiclass VerbatimBlockCommand<string name, string endCommandName> { |
| def Begin : Command<name> { |
| let EndCommandName = endCommandName; |
| let IsVerbatimBlockCommand = 1; |
| } |
| |
| def End : Command<endCommandName> { |
| let IsVerbatimBlockEndCommand = 1; |
| } |
| } |
| |
| class VerbatimLineCommand<string name> : Command<name> { |
| let IsVerbatimLineCommand = 1; |
| } |
| |
| class DeclarationVerbatimLineCommand<string name> : |
| VerbatimLineCommand<name> { |
| let IsDeclarationCommand = 1; |
| } |
| |
| class FunctionDeclarationVerbatimLineCommand<string name> : |
| DeclarationVerbatimLineCommand<name> { |
| let IsFunctionDeclarationCommand = 1; |
| } |
| |
| class RecordLikeDeclarationVerbatimLineCommand<string name> : |
| DeclarationVerbatimLineCommand<name> { |
| let IsRecordLikeDeclarationCommand = 1; |
| } |
| |
| //===----------------------------------------------------------------------===// |
| // InlineCommand |
| //===----------------------------------------------------------------------===// |
| |
| def B : InlineCommand<"b">; |
| def C : InlineCommand<"c">; |
| def P : InlineCommand<"p">; |
| def A : InlineCommand<"a">; |
| def E : InlineCommand<"e">; |
| def Em : InlineCommand<"em">; |
| |
| //===----------------------------------------------------------------------===// |
| // BlockCommand |
| //===----------------------------------------------------------------------===// |
| |
| def Brief : BlockCommand<"brief"> { let IsBriefCommand = 1; } |
| def Short : BlockCommand<"short"> { let IsBriefCommand = 1; } |
| |
| // Opposite of \brief, it is the default in our implementation. |
| def Details : BlockCommand<"details">; |
| |
| def Returns : BlockCommand<"returns"> { let IsReturnsCommand = 1; } |
| def Return : BlockCommand<"return"> { let IsReturnsCommand = 1; } |
| def Result : BlockCommand<"result"> { let IsReturnsCommand = 1; } |
| |
| def Param : BlockCommand<"param"> { let IsParamCommand = 1; } |
| |
| // Doxygen command for template parameter documentation. |
| def Tparam : BlockCommand<"tparam"> { let IsTParamCommand = 1; } |
| |
| // HeaderDoc command for template parameter documentation. |
| def Templatefield : BlockCommand<"templatefield"> { let IsTParamCommand = 1; } |
| |
| def Throws : BlockCommand<"throws"> { let IsThrowsCommand = 1; } |
| def Throw : BlockCommand<"throw"> { let IsThrowsCommand = 1; } |
| def Exception : BlockCommand<"exception"> { let IsThrowsCommand = 1; } |
| |
| def Deprecated : BlockCommand<"deprecated"> { |
| let IsEmptyParagraphAllowed = 1; |
| let IsDeprecatedCommand = 1; |
| } |
| |
| def Headerfile : BlockCommand<"headerfile"> { let IsHeaderfileCommand = 1; } |
| |
| // We don't do any additional semantic analysis for the following |
| // BlockCommands. It might be a good idea to do something extra for them, but |
| // for now we model them as plain BlockCommands. |
| def Arg : BlockCommand<"arg">; |
| def Attention : BlockCommand<"attention">; |
| def Author : BlockCommand<"author">; |
| def Authors : BlockCommand<"authors">; |
| def Bug : BlockCommand<"bug">; |
| def Copyright : BlockCommand<"copyright">; |
| def Date : BlockCommand<"date">; |
| def Invariant : BlockCommand<"invariant">; |
| def Li : BlockCommand<"li">; |
| def Note : BlockCommand<"note">; |
| def Par : BlockCommand<"par">; |
| def Post : BlockCommand<"post">; |
| def Pre : BlockCommand<"pre">; |
| def Remark : BlockCommand<"remark">; |
| def Remarks : BlockCommand<"remarks">; |
| def Sa : BlockCommand<"sa">; |
| def See : BlockCommand<"see">; |
| def Since : BlockCommand<"since">; |
| def Todo : BlockCommand<"todo">; |
| def Version : BlockCommand<"version">; |
| def Warning : BlockCommand<"warning">; |
| // HeaderDoc commands |
| def Abstract : BlockCommand<"abstract"> { let IsBriefCommand = 1; } |
| def ClassDesign : RecordLikeDetailCommand<"classdesign">; |
| def CoClass : RecordLikeDetailCommand<"coclass">; |
| def Dependency : RecordLikeDetailCommand<"dependency">; |
| def Discussion : BlockCommand<"discussion">; |
| def Helper : RecordLikeDetailCommand<"helper">; |
| def HelperClass : RecordLikeDetailCommand<"helperclass">; |
| def Helps : RecordLikeDetailCommand<"helps">; |
| def InstanceSize : RecordLikeDetailCommand<"instancesize">; |
| def Ownership : RecordLikeDetailCommand<"ownership">; |
| def Performance : RecordLikeDetailCommand<"performance">; |
| def Security : RecordLikeDetailCommand<"security">; |
| def SeeAlso : BlockCommand<"seealso">; |
| def SuperClass : RecordLikeDetailCommand<"superclass">; |
| |
| //===----------------------------------------------------------------------===// |
| // VerbatimBlockCommand |
| //===----------------------------------------------------------------------===// |
| |
| defm Code : VerbatimBlockCommand<"code", "endcode">; |
| defm Verbatim : VerbatimBlockCommand<"verbatim", "endverbatim">; |
| defm Htmlonly : VerbatimBlockCommand<"htmlonly", "endhtmlonly">; |
| defm Latexonly : VerbatimBlockCommand<"latexonly", "endlatexonly">; |
| defm Xmlonly : VerbatimBlockCommand<"xmlonly", "endxmlonly">; |
| defm Manonly : VerbatimBlockCommand<"manonly", "endmanonly">; |
| defm Rtfonly : VerbatimBlockCommand<"rtfonly", "endrtfonly">; |
| |
| defm Dot : VerbatimBlockCommand<"dot", "enddot">; |
| defm Msc : VerbatimBlockCommand<"msc", "endmsc">; |
| |
| // These three commands have special support in CommentLexer to recognize their |
| // names. |
| def FDollar : VerbatimBlockCommand<"f$">; // Inline LaTeX formula |
| defm FBracket : VerbatimBlockCommand<"f[", "f]">; // Displayed LaTeX formula |
| defm FBrace : VerbatimBlockCommand<"f{", "f}">; // LaTeX environment |
| |
| // HeaderDoc commands |
| defm Textblock : VerbatimBlockCommand<"textblock", "/textblock">; |
| defm Link : VerbatimBlockCommand<"link", "/link">; |
| |
| //===----------------------------------------------------------------------===// |
| // VerbatimLineCommand |
| //===----------------------------------------------------------------------===// |
| |
| def Defgroup : VerbatimLineCommand<"defgroup">; |
| def Ingroup : VerbatimLineCommand<"ingroup">; |
| def Addtogroup : VerbatimLineCommand<"addtogroup">; |
| def Weakgroup : VerbatimLineCommand<"weakgroup">; |
| def Name : VerbatimLineCommand<"name">; |
| |
| def Section : VerbatimLineCommand<"section">; |
| def Subsection : VerbatimLineCommand<"subsection">; |
| def Subsubsection : VerbatimLineCommand<"subsubsection">; |
| def Paragraph : VerbatimLineCommand<"paragraph">; |
| |
| def Mainpage : VerbatimLineCommand<"mainpage">; |
| def Subpage : VerbatimLineCommand<"subpage">; |
| def Ref : VerbatimLineCommand<"ref">; |
| |
| def Relates : VerbatimLineCommand<"relates">; |
| def Related : VerbatimLineCommand<"related">; |
| def RelatesAlso : VerbatimLineCommand<"relatesalso">; |
| def RelatedAlso : VerbatimLineCommand<"relatedalso">; |
| |
| //===----------------------------------------------------------------------===// |
| // DeclarationVerbatimLineCommand |
| //===----------------------------------------------------------------------===// |
| |
| // Doxygen commands. |
| def Def : DeclarationVerbatimLineCommand<"def">; |
| def Fn : DeclarationVerbatimLineCommand<"fn">; |
| def Namespace : DeclarationVerbatimLineCommand<"namespace">; |
| def Overload : DeclarationVerbatimLineCommand<"overload">; |
| def Property : DeclarationVerbatimLineCommand<"property">; |
| def Typedef : DeclarationVerbatimLineCommand<"typedef">; |
| def Var : DeclarationVerbatimLineCommand<"var">; |
| |
| // HeaderDoc commands. |
| def Class : RecordLikeDeclarationVerbatimLineCommand<"class">; |
| def Interface : RecordLikeDeclarationVerbatimLineCommand<"interface">; |
| def Protocol : RecordLikeDeclarationVerbatimLineCommand<"protocol">; |
| def Struct : RecordLikeDeclarationVerbatimLineCommand<"struct">; |
| def Union : RecordLikeDeclarationVerbatimLineCommand<"union">; |
| def Category : DeclarationVerbatimLineCommand<"category">; |
| def Template : DeclarationVerbatimLineCommand<"template">; |
| def Function : FunctionDeclarationVerbatimLineCommand<"function">; |
| def FunctionGroup : FunctionDeclarationVerbatimLineCommand<"functiongroup">; |
| def Method : FunctionDeclarationVerbatimLineCommand<"method">; |
| def MethodGroup : FunctionDeclarationVerbatimLineCommand<"methodgroup">; |
| def Callback : FunctionDeclarationVerbatimLineCommand<"callback">; |
| def Const : DeclarationVerbatimLineCommand<"const">; |
| def Constant : DeclarationVerbatimLineCommand<"constant">; |
| def Enum : DeclarationVerbatimLineCommand<"enum">; |