aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CMakeLists.txt1
-rw-r--r--cpp11-migrate/CMakeLists.txt12
-rw-r--r--cpp11-migrate/Cpp11Migrate.cpp57
-rw-r--r--cpp11-migrate/Makefile26
-rw-r--r--test/CMakeLists.txt2
-rw-r--r--test/cpp11-migrate/syntax_only.cpp7
-rw-r--r--test/cpp11-migrate/syntax_xfail.cpp8
7 files changed, 112 insertions, 1 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 6a3ee684..4755f295 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -2,6 +2,7 @@ add_subdirectory(remove-cstr-calls)
add_subdirectory(tool-template)
add_subdirectory(loop-convert)
add_subdirectory(clang-format)
+add_subdirectory(cpp11-migrate)
# Add the common testsuite after all the tools.
add_subdirectory(test)
diff --git a/cpp11-migrate/CMakeLists.txt b/cpp11-migrate/CMakeLists.txt
new file mode 100644
index 00000000..49c624d4
--- /dev/null
+++ b/cpp11-migrate/CMakeLists.txt
@@ -0,0 +1,12 @@
+set(LLVM_LINK_COMPONENTS support)
+set(LLVM_USED_LIBS clangTooling clangBasic clangAST)
+
+add_clang_executable(cpp11-migrate
+ Cpp11Migrate.cpp
+ )
+
+target_link_libraries(cpp11-migrate
+ clangTooling
+ clangBasic
+ clangASTMatchers
+ )
diff --git a/cpp11-migrate/Cpp11Migrate.cpp b/cpp11-migrate/Cpp11Migrate.cpp
new file mode 100644
index 00000000..0e720462
--- /dev/null
+++ b/cpp11-migrate/Cpp11Migrate.cpp
@@ -0,0 +1,57 @@
+//===-- cpp11-migrate/Cpp11Migrate.cpp - Main file C++11 migration tool ---===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+///
+/// \file
+/// \brief This file implements the C++11 feature migration tool main function
+/// and transformation framework.
+///
+/// Usage:
+/// cpp11-migrate [-p <build-path>] <file1> <file2> ... [-- [compiler-options]]
+///
+/// Where <build-path> is a CMake build directory containing a file named
+/// compile_commands.json which provides compiler options for building each
+/// sourc file. If <build-path> is not provided the compile_commands.json file
+/// is searched for through all parent directories.
+///
+/// Alternatively, one can provide compile options to be applied to every source
+/// file after the optional '--'.
+///
+/// <file1>... specify the paths of files in the CMake source tree, with the
+/// same requirements as other tools built on LibTooling.
+///
+//===----------------------------------------------------------------------===//
+
+#include "clang/Basic/FileManager.h"
+#include "clang/Frontend/CompilerInstance.h"
+#include "clang/Frontend/FrontendActions.h"
+#include "clang/Tooling/Refactoring.h"
+#include "clang/Tooling/Tooling.h"
+#include "clang/Tooling/CommonOptionsParser.h"
+
+namespace cl = llvm::cl;
+using namespace clang::tooling;
+
+
+int main(int argc, const char **argv) {
+ CommonOptionsParser OptionsParser(argc, argv);
+
+ // TODO: Create transforms requested by command-line.
+ ClangTool SyntaxTool(OptionsParser.GetCompilations(),
+ OptionsParser.GetSourcePathList());
+
+ // First, let's check to make sure there were no errors.
+ if (SyntaxTool.run(newFrontendActionFactory<clang::SyntaxOnlyAction>()) !=
+ 0) {
+ return 1;
+ }
+
+ // TODO: Apply transforms
+
+ return 0;
+}
diff --git a/cpp11-migrate/Makefile b/cpp11-migrate/Makefile
new file mode 100644
index 00000000..98d9b1e7
--- /dev/null
+++ b/cpp11-migrate/Makefile
@@ -0,0 +1,26 @@
+##===- tools/extra/loop-convert/Makefile ----sssss----------*- Makefile -*-===##
+#
+# The LLVM Compiler Infrastructure
+#
+# This file is distributed under the University of Illinois Open Source
+# License. See LICENSE.TXT for details.
+#
+##===----------------------------------------------------------------------===##
+
+CLANG_LEVEL := ../../..
+
+TOOLNAME = cpp11-migrate
+NO_INSTALL = 1
+
+# No plugins, optimize startup time.
+TOOL_NO_EXPORTS = 1
+
+include $(CLANG_LEVEL)/../../Makefile.config
+LINK_COMPONENTS := $(TARGETS_TO_BUILD) asmparser support mc
+USEDLIBS = clangTooling.a clangFrontend.a clangSerialization.a clangDriver.a \
+ clangRewriteFrontend.a clangRewriteCore.a clangParse.a \
+ clangSema.a clangAnalysis.a \
+ clangAST.a clangASTMatchers.a clangEdit.a clangLex.a clangBasic.a
+
+include $(CLANG_LEVEL)/Makefile
+
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 9c0d1824..be12d199 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -22,7 +22,7 @@ set(CLANG_TOOLS_TEST_DEPS
clang clang-headers FileCheck count not
# Individual tools we test.
- remove-cstr-calls loop-convert
+ remove-cstr-calls loop-convert cpp11-migrate
)
add_lit_testsuite(check-clang-tools "Running the Clang extra tools' regression tests"
diff --git a/test/cpp11-migrate/syntax_only.cpp b/test/cpp11-migrate/syntax_only.cpp
new file mode 100644
index 00000000..eaceb357
--- /dev/null
+++ b/test/cpp11-migrate/syntax_only.cpp
@@ -0,0 +1,7 @@
+// RUN: grep -Ev "// *[A-Z-]+:" %s > %t.cpp
+// RUN: cpp11-migrate %t.cpp --
+// REQUIRES: shell
+
+int main(int argc, char** argv) {
+ return 0;
+}
diff --git a/test/cpp11-migrate/syntax_xfail.cpp b/test/cpp11-migrate/syntax_xfail.cpp
new file mode 100644
index 00000000..0c5c652a
--- /dev/null
+++ b/test/cpp11-migrate/syntax_xfail.cpp
@@ -0,0 +1,8 @@
+// RUN: grep -Ev "// *[A-Z-]+:" %s > %t.cpp
+// RUN: cpp11-migrate %t.cpp --
+// XFAIL: *
+// REQUIRES: shell
+
+int main(int argc, char** argv) {
+i return 0;
+}