llvm-cov: Very basic top level help
authorJustin Bogner <mail@justinbogner.com>
Thu, 30 Oct 2014 20:29:48 +0000 (20:29 +0000)
committerJustin Bogner <mail@justinbogner.com>
Thu, 30 Oct 2014 20:29:48 +0000 (20:29 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@220926 91177308-0d34-0410-b5e6-96231b3b80d8

tools/llvm-cov/llvm-cov.cpp

index 8c1ad8bedb3f37b5da698bbc37382c9cee4a60d5..132c187ef9eb72f5291ac2656fb878bd96cd5151 100644 (file)
@@ -12,6 +12,7 @@
 //===----------------------------------------------------------------------===//
 
 #include "llvm/ADT/StringRef.h"
+#include "llvm/ADT/StringSwitch.h"
 #include "llvm/Support/raw_ostream.h"
 #include "llvm/Support/Path.h"
 #include <string>
@@ -30,6 +31,13 @@ int convert_for_testing_main(int argc, const char **argv);
 /// \brief The main entry point for the gcov compatible coverage tool.
 int gcov_main(int argc, const char **argv);
 
+/// \brief Top level help.
+int help_main(int argc, const char **argv) {
+  errs() << "OVERVIEW: LLVM code coverage tool\n\n"
+         << "USAGE: llvm-cov {gcov|report|show}\n";
+  return 0;
+}
+
 int main(int argc, const char **argv) {
   // If argv[0] is or ends with 'gcov', always be gcov compatible
   if (sys::path::stem(argv[0]).endswith_lower("gcov"))
@@ -37,17 +45,15 @@ int main(int argc, const char **argv) {
 
   // Check if we are invoking a specific tool command.
   if (argc > 1) {
-    int (*func)(int, const char **) = nullptr;
-
-    StringRef command = argv[1];
-    if (command.equals_lower("show"))
-      func = show_main;
-    else if (command.equals_lower("report"))
-      func = report_main;
-    else if (command.equals_lower("convert-for-testing"))
-      func = convert_for_testing_main;
-    else if (command.equals_lower("gcov"))
-      func = gcov_main;
+    typedef int (*MainFunction)(int, const char **);
+    MainFunction func =
+        StringSwitch<MainFunction>(argv[1])
+            .Case("convert-for-testing", convert_for_testing_main)
+            .Case("gcov", gcov_main)
+            .Case("report", report_main)
+            .Case("show", show_main)
+            .Cases("-h", "-help", "--help", help_main)
+            .Default(nullptr);
 
     if (func) {
       std::string Invocation = std::string(argv[0]) + " " + argv[1];