mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-28 15:54:32 +00:00
571c71e6f7
We are migrating packages that meet below requirements: 1. using `callPackage` 2. called path is a directory 3. overriding set is empty (`{ }`) 4. not containing path expressions other than relative path (to makenixpkgs-vet happy) 5. not referenced by nix files outside of the directory, other than`pkgs/top-level/all-packages.nix` 6. not referencing nix files outside of the directory 7. not referencing `default.nix` (since it's changed to `package.nix`) 8. `outPath` doesn't change after migration The tool is here: https://github.com/Aleksanaa/by-name-migrate.
40 lines
1.3 KiB
Diff
40 lines
1.3 KiB
Diff
diff --git a/svr-chansession.c b/svr-chansession.c
|
|
index 9ae2e60..2db7598 100644
|
|
--- a/svr-chansession.c
|
|
+++ b/svr-chansession.c
|
|
@@ -948,6 +948,8 @@ static void addchildpid(struct ChanSess *chansess, pid_t pid) {
|
|
static void execchild(const void *user_data) {
|
|
const struct ChanSess *chansess = user_data;
|
|
char *usershell = NULL;
|
|
+ const char *path = (getuid() == 0) ? DEFAULT_ROOT_PATH : DEFAULT_PATH;
|
|
+ const char *ldpath = NULL;
|
|
char *cp = NULL;
|
|
char *envcp = getenv("LANG");
|
|
if (envcp != NULL) {
|
|
@@ -965,6 +967,11 @@ static void execchild(const void *user_data) {
|
|
seedrandom();
|
|
#endif
|
|
|
|
+ if (getenv("PATH")) {
|
|
+ path = getenv("PATH");
|
|
+ }
|
|
+ ldpath = getenv("LD_LIBRARY_PATH");
|
|
+
|
|
/* clear environment if -e was not set */
|
|
/* if we're debugging using valgrind etc, we need to keep the LD_PRELOAD
|
|
* etc. This is hazardous, so should only be used for debugging. */
|
|
@@ -1012,10 +1019,9 @@ static void execchild(const void *user_data) {
|
|
addnewvar("LOGNAME", ses.authstate.pw_name);
|
|
addnewvar("HOME", ses.authstate.pw_dir);
|
|
addnewvar("SHELL", get_user_shell());
|
|
- if (getuid() == 0) {
|
|
- addnewvar("PATH", DEFAULT_ROOT_PATH);
|
|
- } else {
|
|
- addnewvar("PATH", DEFAULT_PATH);
|
|
+ addnewvar("PATH", path);
|
|
+ if (ldpath != NULL) {
|
|
+ addnewvar("LD_LIBRARY_PATH", ldpath);
|
|
}
|
|
if (cp != NULL) {
|
|
addnewvar("LANG", cp);
|