summaryrefslogtreecommitdiff
path: root/.ycm_extra_conf.py
diff options
context:
space:
mode:
authorThiago Marcos P. Santos <thiago@mapbox.com>2015-06-26 16:31:53 +0300
committerThiago Marcos P. Santos <thiago@mapbox.com>2015-06-29 11:18:24 +0300
commit0fdb4f7b4ceb06aec4fb7d65083a942751fb7669 (patch)
tree1512daefb1bf2d89591c020f0eae483a703cbd57 /.ycm_extra_conf.py
parentac2ad993a594e309362787e0697ff1727b799e8e (diff)
downloadqtlocation-mapboxgl-0fdb4f7b4ceb06aec4fb7d65083a942751fb7669.tar.gz
Add YCM config file for VIM users
Tailor-made for Mapbox GL Native. For instructions of how to use, see: https://github.com/Valloric/YouCompleteMe
Diffstat (limited to '.ycm_extra_conf.py')
-rw-r--r--.ycm_extra_conf.py123
1 files changed, 123 insertions, 0 deletions
diff --git a/.ycm_extra_conf.py b/.ycm_extra_conf.py
new file mode 100644
index 0000000000..3b0ee6de67
--- /dev/null
+++ b/.ycm_extra_conf.py
@@ -0,0 +1,123 @@
+# Adapted version of .ycm_extra_conf.py sample file adapted
+# for the Mapbox GL Native project.
+#
+# This file is NOT licensed under the GPLv3, which is the license for the rest
+# of YouCompleteMe.
+#
+# Here's the license text for this file:
+#
+# This is free and unencumbered software released into the public domain.
+#
+# Anyone is free to copy, modify, publish, use, compile, sell, or
+# distribute this software, either in source code form or as a compiled
+# binary, for any purpose, commercial or non-commercial, and by any
+# means.
+#
+# In jurisdictions that recognize copyright laws, the author or authors
+# of this software dedicate any and all copyright interest in the
+# software to the public domain. We make this dedication for the benefit
+# of the public at large and to the detriment of our heirs and
+# successors. We intend this dedication to be an overt act of
+# relinquishment in perpetuity of all present and future rights to this
+# software under copyright law.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+# IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
+# OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+# OTHER DEALINGS IN THE SOFTWARE.
+#
+# For more information, please refer to <http://unlicense.org/>
+
+import os
+import subprocess
+import sys
+import ycm_core
+
+
+def DirectoryOfThisScript():
+ return os.path.dirname(os.path.abspath(__file__))
+
+
+default_flags = [
+ '-std=c++14',
+ '-I%s' % (os.path.join(DirectoryOfThisScript(), 'src')),
+ '-I%s' % (os.path.join(DirectoryOfThisScript(), 'include')),
+]
+
+
+def MakeRelativePathsInFlagsAbsolute(flags, working_directory):
+ if not working_directory:
+ return list(flags)
+
+ new_flags = []
+ make_next_absolute = False
+ path_flags = ['-isystem', '-I', '-iquote', '--sysroot=']
+
+ for flag in flags:
+ new_flag = flag
+
+ if make_next_absolute:
+ make_next_absolute = False
+ if not flag.startswith('/'):
+ new_flag = os.path.join(working_directory, flag)
+
+ for path_flag in path_flags:
+ if flag == path_flag:
+ make_next_absolute = True
+ break
+
+ if flag.startswith(path_flag):
+ path = flag[len(path_flag):]
+ new_flag = path_flag + os.path.join(working_directory, path)
+ break
+
+ if new_flag:
+ new_flags.append(new_flag)
+
+ return new_flags
+
+
+def FlagsForFileLinux(filename):
+ working_directory = os.path.join('build', 'linux')
+
+ if not os.path.exists(os.path.join(DirectoryOfThisScript(), working_directory)):
+ return {
+ 'flags': default_flags,
+ 'do_cache': False,
+ }
+
+ relative_source_path = filename.replace(DirectoryOfThisScript() + '/', '')
+ relative_obj_path = os.path.splitext(relative_source_path)[0] + '.o'
+
+ make_cmd = 'make -pn |grep %s: |grep GYP_CXXFLAGS |cut -d\' \' -f4-' % relative_obj_path
+
+ p = subprocess.Popen([make_cmd], shell=True, stdout=subprocess.PIPE)
+ stdout, stderr = p.communicate()
+
+ if p.returncode:
+ return {
+ 'flags': default_flags,
+ 'do_cache': False,
+ }
+
+ flags = stdout.split(' ')
+ flags_relative = MakeRelativePathsInFlagsAbsolute(flags, os.path.join(DirectoryOfThisScript(), working_directory))
+ flags_final = [flag for flag in flags_relative if flag.startswith("-")]
+
+ return {
+ 'flags': flags_final,
+ 'do_cache': True,
+ }
+
+
+def FlagsForFile(filename, **kwargs):
+ if sys.platform.startswith('linux'):
+ return FlagsForFileLinux(filename)
+
+ return {
+ 'flags': default_flags,
+ 'do_cache': False,
+ }