aboutsummaryrefslogtreecommitdiff
path: root/tools/generate_clang_complete.py
diff options
context:
space:
mode:
Diffstat (limited to 'tools/generate_clang_complete.py')
-rw-r--r--tools/generate_clang_complete.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/tools/generate_clang_complete.py b/tools/generate_clang_complete.py
new file mode 100644
index 00000000..44da60f3
--- /dev/null
+++ b/tools/generate_clang_complete.py
@@ -0,0 +1,43 @@
+import os
+import os.path
+
+clang_complete_file_name = '.clang_complete'
+
+# project root dir
+project_root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
+os.chdir(project_root)
+
+global_std_standard = 'c++17' # change this to change standard
+global_std_standard_arg = '-std={}'.format(global_std_standard)
+
+global_include_paths = [
+ os.path.abspath('include')
+]
+
+global_definitions = []
+
+
+def generate_clang_complete_content(additional_include_paths=[], additional_definitions=[]):
+ include_args = [
+ '-I{}'.format(path) for path in additional_include_paths + global_include_paths]
+ definition_args = [
+ '-D{}'.format(definition) for definition in additional_definitions + global_definitions]
+ args = [global_std_standard_arg] + include_args + definition_args
+ return '\n'.join(args)
+
+
+def generate_root_clang_complete():
+ with open(os.path.join('src/', clang_complete_file_name), 'w') as f:
+ print(generate_clang_complete_content(), file=f)
+
+
+def generate_win_clang_complete_content():
+ return generate_clang_complete_content(additional_definitions=['UNICODE', '_UNICODE', 'WIN32', '_WINDOWS'])
+
+
+def generate_win_clang_complete():
+ with open(os.path.join('src/win/', clang_complete_file_name), 'w') as f:
+ print(generate_win_clang_complete_content(), file=f)
+
+generate_root_clang_complete()
+generate_win_clang_complete()