ycmd: use vendored python libs

YouCompleteMe needs the packages to be available in ycmd's third_party
directory, and things start getting pretty complicated when we try to
use our package libs instead of the vendored ones. We can revisit this
at a later time, but we'll need to ensure that we don't break the vim
plugin.

Tested in vim.
This commit is contained in:
Charles Strahan 2017-02-09 23:39:16 -05:00
parent b27edc4537
commit 53a5117cde
No known key found for this signature in database
GPG Key ID: BB47AB4B8489B5A5
3 changed files with 64 additions and 24 deletions

View File

@ -0,0 +1,40 @@
diff --git a/cpp/ycm/CMakeLists.txt b/cpp/ycm/CMakeLists.txt
index 2074c58e..9ecd6e57 100644
--- a/cpp/ycm/CMakeLists.txt
+++ b/cpp/ycm/CMakeLists.txt
@@ -366,35 +366,6 @@ if( LIBCLANG_TARGET )
POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy "${LIBCLANG_TARGET}" "$<TARGET_FILE_DIR:${PROJECT_NAME}>"
)
-
- if( APPLE )
- # In OS X El Capitan, Apple introduced System Integrity Protection.
- # Amongst other things, this introduces features to the dynamic loader
- # (dyld) which cause it to "sanitise" (and complain about) embedded
- # LC_RPATH entries which contain @executable_path when then are loaded
- # into "restricted" binaries. For our purposes, "restricted" here means
- # "supplied by Apple" and includes the system versions of python. For
- # unknown reasons, the libclang.dylib that comes from llvm.org includes an
- # LC_RPATH entry '@executable_path/../lib' which causes the OS X dynamic
- # loader to print a cryptic warning to stderr of the form:
- #
- # dyld: warning, LC_RPATH @executable_path/../lib in
- # /path/to/ycmd/libclang.dylib being ignored in restricted program
- # because of @executable_path
- #
- # In order to prevent this harmless and annoying message appearing, we
- # simply strip the rpath entry from the dylib. There's no way any
- # @executable_path that python might have could be in any way useful to
- # libclang.dylib, so this seems perfectly safe.
- get_filename_component( LIBCLANG_TAIL ${LIBCLANG_TARGET} NAME )
- add_custom_command( TARGET ${PROJECT_NAME}
- POST_BUILD
- COMMAND install_name_tool
- "-delete_rpath"
- "@executable_path/../lib"
- "$<TARGET_FILE_DIR:${PROJECT_NAME}>/${LIBCLANG_TAIL}"
- )
- endif()
endif()
endif()

View File

@ -1,16 +1,13 @@
{ stdenv, lib, fetchgit, cmake, llvmPackages, boost, python2Packages
{ stdenv, lib, fetchgit, cmake, llvmPackages, boost, python
, gocode ? null
, godef ? null
, rustracerd ? null
, Cocoa ? null
}:
let
inherit (python2Packages) python mkPythonDerivation waitress frozendict bottle future argparse requests;
pathFixup = "import os; os.environ['PATH'] = ('{0}:{1}' if os.getenv('PATH', '') != '' else '{1}').format('$program_PATH', os.getenv('PATH', ''))";
in mkPythonDerivation rec {
stdenv.mkDerivation rec {
name = "ycmd-${version}";
version = "2017-02-03";
namePrefix = "";
src = fetchgit {
url = "git://github.com/Valloric/ycmd.git";
@ -18,30 +15,32 @@ in mkPythonDerivation rec {
sha256 = "0rzxgqqqmmrv9r4k2ji074iprhw6sb0jkvh84wvi45yfyphsh0xi";
};
buildInputs = [ cmake boost ];
propagatedBuildInputs = [ waitress frozendict bottle future argparse requests ];
buildInputs = [ cmake boost ] ++ stdenv.lib.optional stdenv.isDarwin Cocoa;
buildPhase = ''
export EXTRA_CMAKE_ARGS=-DPATH_TO_LLVM_ROOT=${llvmPackages.clang-unwrapped}
${python.interpreter} build.py --clang-completer --system-boost
'';
patches = [ ./2-ycm-cmake.patch ];
configurePhase = ":";
# remove the tests
#
# make __main__.py executable so mkPythonDerivation's postFixup modifies the
# executable (e.g. fixup PYTHONPATH)
# make __main__.py executable and add shebang
#
# add a shebang (will be rewritten by postFixup)
# copy over third-party libs
# note: if we switch to using our packaged libs, we'll need to symlink them
# into the same spots, as YouCompleteMe (the vim plugin) expects those paths
# to be available
#
# symlink completion backends where ycmd expects them
installPhase = ''
rm -rf ycmd/tests
chmod +x ycmd/__main__.py
sed -i "1i #!/usr/bin/env python\
sed -i "1i #!${python.interpreter}\
" ycmd/__main__.py
mkdir -p $out/lib/ycmd
@ -51,7 +50,12 @@ in mkPythonDerivation rec {
ln -s $out/lib/ycmd/ycmd/__main__.py $out/bin/ycmd
mkdir -p $out/lib/ycmd/third_party/{gocode,godef,racerd/target/release}
cp -r third_party/JediHTTP/ $out/lib/ycmd/third_party
cp -r third_party/JediHTTP $out/lib/ycmd/third_party
for p in waitress frozendict bottle python-future argparse requests; do
cp -r third_party/$p $out/lib/ycmd/third_party
done
'' + lib.optionalString (gocode != null) ''
ln -s ${gocode}/bin/gocode $out/lib/ycmd/third_party/gocode
'' + lib.optionalString (godef != null) ''
@ -60,16 +64,9 @@ in mkPythonDerivation rec {
ln -s ${rustracerd}/bin/racerd $out/lib/ycmd/third_party/racerd/target/release
'';
# mkPythonDerivation will attempt to create a wrapper script (written in bash)
# but we don't want the indirection as several editor plugins want to invoke
# ycmd as `python path/to/ycmd`, which will obviously fail in that case -
# so we move the original file back over
#
# also fixup the argv[0] and replace __file__ with the corresponding path so
# fixup the argv[0] and replace __file__ with the corresponding path so
# python won't be thrown off by argv[0]
postFixup = ''
mv $out/lib/ycmd/ycmd/{.__main__.py-wrapped,__main__.py}
substituteInPlace $out/lib/ycmd/ycmd/__main__.py \
--replace $out/lib/ycmd/ycmd/__main__.py \
$out/bin/ycmd \
@ -81,7 +78,7 @@ in mkPythonDerivation rec {
description = "A code-completion and comprehension server";
homepage = https://github.com/Valloric/ycmd;
license = licenses.gpl3;
maintainers = with maintainers; [ rasendubi ];
maintainers = with maintainers; [ rasendubi cstrahan ];
platforms = platforms.all;
};
}

View File

@ -6785,7 +6785,10 @@ with pkgs;
yacc = bison;
ycmd = callPackage ../development/tools/misc/ycmd { };
ycmd = callPackage ../development/tools/misc/ycmd {
inherit (darwin.apple_sdk.frameworks) Cocoa;
python = python2;
};
yodl = callPackage ../development/tools/misc/yodl { };