Declaring these helpers in the ast_matcher namespace in the clangAST
unit test seems inappropriate -- neither these helpers, nor clangAST have
anything to do with AST matchers. Therefore, I moved these helpers to
the clang namespace.
Declaring another typedef called "ArgVector" is not a good idea -- we
already have both "ArgVector", "ArgsVector", and "ArgList". I expanded
it into the underlying type.
Declaring another enum called "Language" is not a good idea because we
arleady have the "clang::Language" enum. I renamed it to
"TestLanguage".
Similarly, I renamed "getBasicRunOptionsForLanguage" to
"getCommandLineArgsForTesting" to explain the semantics better (what are
"run options"?) and not repeat types in the function name
("ForLanguage").
this enum doesn't seem great: why is the default CXX (presumably) 98? How do you get objc++ with 14 features?
(No need to address this now, but it's not clear this is a great API to spread more widely. Vs e.g.
struct TestLanguage { static TestLanguage CXX; // some arbitrary version static TestLanguage C; enum { CXX98, CXX11, } CXXVersion; vector<string> getCommandLineArgs(); }