diff options
author | 杨宇千 <crupest@outlook.com> | 2019-07-10 17:23:29 +0800 |
---|---|---|
committer | 杨宇千 <crupest@outlook.com> | 2019-07-10 17:23:29 +0800 |
commit | d163bafa461779a3795818aa8c8b5238880ede24 (patch) | |
tree | 9eadf181655e293158cab095bb688cad9c0b1f18 /tools/generate_clang_complete.py | |
parent | e37dd256e5bca4caf819d18c73cd2d11e06683df (diff) | |
download | cru-d163bafa461779a3795818aa8c8b5238880ede24.tar.gz cru-d163bafa461779a3795818aa8c8b5238880ede24.tar.bz2 cru-d163bafa461779a3795818aa8c8b5238880ede24.zip |
...
Diffstat (limited to 'tools/generate_clang_complete.py')
-rw-r--r-- | tools/generate_clang_complete.py | 43 |
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() |