diff options
author | Sean Silva <silvas@purdue.edu> | 2013-03-21 23:40:38 +0000 |
---|---|---|
committer | Sean Silva <silvas@purdue.edu> | 2013-03-21 23:40:38 +0000 |
commit | 426db657da8753921f21c676b91c527e1b77878c (patch) | |
tree | 0654858c8a490fad7271234abcf4b44962de736b /utils/TableGen/TableGen.cpp | |
parent | d9ff8c83d137586d8c06f98bdf8adbf0d1fa79ca (diff) | |
download | external_llvm-426db657da8753921f21c676b91c527e1b77878c.zip external_llvm-426db657da8753921f21c676b91c527e1b77878c.tar.gz external_llvm-426db657da8753921f21c676b91c527e1b77878c.tar.bz2 |
Add TableGen ctags(1) emitter and helper script.
To use this in conjunction with exuberant ctags to generate a single
combined tags file, run tblgen first and then
$ ctags --append [...]
Since some identifiers have corresponding definitions in C++ code,
it can be useful (if using vim) to also use cscope, and
:set cscopetagorder=1
so that
:tag X
will preferentially select the tablegen symbol, while
:cscope find g X
will always find the C++ symbol.
Patch by Kevin Schoedel!
(a couple small formatting changes courtesy of clang-format)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@177682 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/TableGen.cpp')
-rw-r--r-- | utils/TableGen/TableGen.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/utils/TableGen/TableGen.cpp b/utils/TableGen/TableGen.cpp index 510f254..b5c3ca7 100644 --- a/utils/TableGen/TableGen.cpp +++ b/utils/TableGen/TableGen.cpp @@ -40,7 +40,8 @@ enum ActionType { GenTgtIntrinsic, PrintEnums, PrintSets, - GenOptParserDefs + GenOptParserDefs, + GenCTags }; namespace { @@ -82,6 +83,8 @@ namespace { "Print expanded sets for testing DAG exprs"), clEnumValN(GenOptParserDefs, "gen-opt-parser-defs", "Generate option definitions"), + clEnumValN(GenCTags, "gen-ctags", + "Generate ctags-compatible index"), clEnumValEnd)); cl::opt<std::string> @@ -161,6 +164,9 @@ bool LLVMTableGenMain(raw_ostream &OS, RecordKeeper &Records) { } break; } + case GenCTags: + EmitCTags(Records, OS); + break; } return false; |