diff --git a/src/modules/languages/python.nix b/src/modules/languages/python.nix index 9c6aef053..bb6af3905 100644 --- a/src/modules/languages/python.nix +++ b/src/modules/languages/python.nix @@ -14,6 +14,9 @@ let python = cfg.package; requiredPythonModules = cfg.package.pkgs.requiredPythonModules; makeWrapperArgs = [ + "--set" + "DEVENV_LD_LIBRARY_PATH_PREFIX" + libraries "--prefix" "LD_LIBRARY_PATH" ":" @@ -39,6 +42,20 @@ let follows = [ "nixpkgs" ]; }; + pth_file = + let + exec_content = '' + ld_library_path = os.environ.get("LD_LIBRARY_PATH") + ld_library_path_prefix = os.environ.get("DEVENV_LD_LIBRARY_PATH_PREFIX") + if ld_library_path and ld_library_path_prefix: + if ld_library_path == ld_library_path_prefix: + del os.environ["LD_LIBRARY_PATH"] + else: + os.environ["LD_LIBRARY_PATH"] = ld_library_path.removeprefix(ld_library_path_prefix + ":") + ''; + in + pkgs.writeText "devenv.pth" ''import os; exec("""${builtins.replaceStrings [ "\n" ] [ "\\n" ] exec_content}""")''; + initVenvScript = let USE_UV_SYNC = cfg.uv.sync.enable && builtins.compareVersions cfg.uv.package.version "0.4.4" >= 0; @@ -80,6 +97,9 @@ let '' } echo "${package.interpreter}" > "$VENV_PATH/.devenv_interpreter" + ${lib.optionalString pkgs.stdenv.isLinux '' + ln -snf ${pth_file} "$VENV_PATH/${package.sitePackages}/devenv.pth" + ''} fi source "$VENV_PATH"/bin/activate @@ -157,6 +177,9 @@ let if "''${UV_SYNC_COMMAND[@]}" then echo "$ACTUAL_UV_CHECKSUM" > "$UV_CHECKSUM_FILE" + ${lib.optionalString pkgs.stdenv.isLinux '' + ln -snf ${pth_file} "$VENV_PATH/${package.sitePackages}/devenv.pth" + ''} else echo "uv sync failed. Run 'uv sync' manually." >&2 fi @@ -206,6 +229,9 @@ let if ''${POETRY_INSTALL_COMMAND[@]} then echo "$ACTUAL_POETRY_CHECKSUM" > "$POETRY_CHECKSUM_FILE" + ${lib.optionalString pkgs.stdenv.isLinux '' + ln -snf ${pth_file} ".venv/${package.sitePackages}/devenv.pth" + ''} else echo "Poetry install failed. Run 'poetry install' manually." fi