|
|
fecd69 |
diff -up ./NEWS.ori ./NEWS
|
|
|
fecd69 |
--- ./NEWS.ori 2022-08-15 11:59:35.929714848 +0200
|
|
|
fecd69 |
+++ ./NEWS 2022-08-15 12:00:12.892937479 +0200
|
|
|
fecd69 |
@@ -1,4 +1,14 @@
|
|
|
fecd69 |
procps-ng-NEXT
|
|
|
fecd69 |
+<<<<<<< HEAD
|
|
|
fecd69 |
+=======
|
|
|
fecd69 |
+ * library
|
|
|
fecd69 |
+ Re-add elogind support merge #151
|
|
|
fecd69 |
+ * ps: threads again display when -L is used with -q issue #234
|
|
|
fecd69 |
+ * ps: proper aix format string behavior was restored
|
|
|
fecd69 |
+ * sysctl: print dotted keys again
|
|
|
fecd69 |
+
|
|
|
fecd69 |
+procps-ng-4.0.0
|
|
|
fecd69 |
+>>>>>>> b159c198 (sysctl: print dotted keys again)
|
|
|
fecd69 |
---------------
|
|
|
fecd69 |
* Rename pwait to pidwait
|
|
|
fecd69 |
|
|
|
fecd69 |
diff -up ./sysctl.c.ori ./sysctl.c
|
|
|
fecd69 |
--- ./sysctl.c.ori 2022-08-15 11:59:35.934714878 +0200
|
|
|
fecd69 |
+++ ./sysctl.c 2022-08-15 12:00:12.893937485 +0200
|
|
|
fecd69 |
@@ -152,7 +152,7 @@ static SysctlSetting *setting_new(
|
|
|
fecd69 |
strcat(path + proc_len, key+1);
|
|
|
fecd69 |
else
|
|
|
fecd69 |
strcat(path + proc_len, key);
|
|
|
fecd69 |
- /* change . to / */
|
|
|
fecd69 |
+ /* change . to / for path */
|
|
|
fecd69 |
slashdot(path + proc_len, '.', '/');
|
|
|
fecd69 |
|
|
|
fecd69 |
s = xmalloc(sizeof(SysctlSetting));
|
|
|
fecd69 |
@@ -510,7 +510,8 @@ static int WriteSetting(
|
|
|
fecd69 |
|
|
|
fecd69 |
int rc = EXIT_SUCCESS;
|
|
|
fecd69 |
FILE *fp;
|
|
|
fecd69 |
- struct stat ts;
|
|
|
fecd69 |
+ struct stat ts;
|
|
|
fecd69 |
+ char *dotted_key;
|
|
|
fecd69 |
|
|
|
fecd69 |
if (!key || !path)
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
@@ -523,13 +524,22 @@ static int WriteSetting(
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
|
|
|
fecd69 |
- if ((ts.st_mode & S_IWUSR) == 0) {
|
|
|
fecd69 |
- xwarn(_("setting key \"%s\""), key);
|
|
|
fecd69 |
+ /* Convert the globbed path into a dotted key */
|
|
|
fecd69 |
+ if ( (dotted_key = strdup(path + strlen(PROC_PATH))) == NULL) {
|
|
|
fecd69 |
+ xerrx(EXIT_FAILURE, _("strdup key"));
|
|
|
fecd69 |
+ return EXIT_FAILURE;
|
|
|
fecd69 |
+ }
|
|
|
fecd69 |
+ slashdot(dotted_key, '/', '.');
|
|
|
fecd69 |
+
|
|
|
fecd69 |
+ if ((ts.st_mode & S_IWUSR) == 0) {
|
|
|
fecd69 |
+ xwarn(_("setting key \"%s\""), dotted_key);
|
|
|
fecd69 |
+ free(dotted_key);
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
|
|
|
fecd69 |
- if (S_ISDIR(ts.st_mode)) {
|
|
|
fecd69 |
- xwarn(_("setting key \"%s\""), key);
|
|
|
fecd69 |
+ if (S_ISDIR(ts.st_mode)) {
|
|
|
fecd69 |
+ xwarn(_("setting key \"%s\""), dotted_key);
|
|
|
fecd69 |
+ free(dotted_key);
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
|
|
|
fecd69 |
@@ -539,7 +549,7 @@ static int WriteSetting(
|
|
|
fecd69 |
case ENOENT:
|
|
|
fecd69 |
if (!IgnoreError) {
|
|
|
fecd69 |
xwarnx(_("\"%s\" is an unknown key%s"),
|
|
|
fecd69 |
- key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
+ dotted_key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
if (!ignore_failure)
|
|
|
fecd69 |
rc = EXIT_FAILURE;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
@@ -548,11 +558,11 @@ static int WriteSetting(
|
|
|
fecd69 |
case EROFS:
|
|
|
fecd69 |
case EACCES:
|
|
|
fecd69 |
xwarnx(_("permission denied on key \"%s\"%s"),
|
|
|
fecd69 |
- key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
+ dotted_key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
break;
|
|
|
fecd69 |
default:
|
|
|
fecd69 |
xwarn(_("setting key \"%s\"%s"),
|
|
|
fecd69 |
- key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
+ dotted_key, (ignore_failure?_(", ignoring"):""));
|
|
|
fecd69 |
break;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
if (!ignore_failure && errno != ENOENT)
|
|
|
fecd69 |
@@ -561,7 +571,7 @@ static int WriteSetting(
|
|
|
fecd69 |
if (0 < fprintf(fp, "%s\n", value))
|
|
|
fecd69 |
rc = EXIT_SUCCESS;
|
|
|
fecd69 |
if (close_stream(fp) != 0) {
|
|
|
fecd69 |
- xwarn(_("setting key \"%s\""), path);
|
|
|
fecd69 |
+ xwarn(_("setting key \"%s\""), dotted_key);
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
}
|
|
|
fecd69 |
@@ -571,7 +581,7 @@ static int WriteSetting(
|
|
|
fecd69 |
printf("%s\n", value);
|
|
|
fecd69 |
} else {
|
|
|
fecd69 |
if (PrintName) {
|
|
|
fecd69 |
- printf("%s = %s\n", path, value);
|
|
|
fecd69 |
+ printf("%s = %s\n", dotted_key, value);
|
|
|
fecd69 |
} else {
|
|
|
fecd69 |
if (PrintNewline)
|
|
|
fecd69 |
printf("%s\n", value);
|
|
|
fecd69 |
@@ -580,6 +590,7 @@ static int WriteSetting(
|
|
|
fecd69 |
}
|
|
|
fecd69 |
}
|
|
|
fecd69 |
}
|
|
|
fecd69 |
+ free(dotted_key);
|
|
|
fecd69 |
return rc;
|
|
|
fecd69 |
}
|
|
|
fecd69 |
|
|
|
fecd69 |
diff -up ./testsuite/sysctl_slash_test.conf.ori ./testsuite/sysctl_slash_test.conf
|
|
|
fecd69 |
--- ./testsuite/sysctl_slash_test.conf.ori 2022-08-15 12:00:12.894937491 +0200
|
|
|
fecd69 |
+++ ./testsuite/sysctl_slash_test.conf 2022-08-15 12:00:12.893937485 +0200
|
|
|
fecd69 |
@@ -0,0 +1 @@
|
|
|
fecd69 |
+kernel/hostname = procps-test
|
|
|
fecd69 |
diff -up ./testsuite/sysctl.test/sysctl_write.exp.ori ./testsuite/sysctl.test/sysctl_write.exp
|
|
|
fecd69 |
--- ./testsuite/sysctl.test/sysctl_write.exp.ori 2022-08-15 11:59:35.934714878 +0200
|
|
|
fecd69 |
+++ ./testsuite/sysctl.test/sysctl_write.exp 2022-08-15 12:00:12.893937485 +0200
|
|
|
fecd69 |
@@ -3,11 +3,19 @@ set sysctl ${topdir}sysctl
|
|
|
fecd69 |
|
|
|
fecd69 |
set test "sysctl write from command line"
|
|
|
fecd69 |
spawn $sysctl --dry-run kernel.hostname=procps-test
|
|
|
fecd69 |
-expect_pass "$test" "/proc/sys/kernel/hostname = procps-test"
|
|
|
fecd69 |
+expect_pass "$test" "kernel.hostname = procps-test"
|
|
|
fecd69 |
+
|
|
|
fecd69 |
+set test "sysctl write from command line using slash"
|
|
|
fecd69 |
+spawn $sysctl --dry-run kernel/hostname=procps-test
|
|
|
fecd69 |
+expect_pass "$test" "kernel.hostname = procps-test"
|
|
|
fecd69 |
|
|
|
fecd69 |
set test "sysctl write from configuration file"
|
|
|
fecd69 |
spawn $sysctl --dry-run -f ${topdir}testsuite/sysctl_glob_test.conf
|
|
|
fecd69 |
-expect_pass "$test" "/proc/sys/fs/protected_fifos = 2\\s+/proc/sys/fs/protected_symlinks = 2\\s+/proc/sys/fs/protected_hardlinks = 1"
|
|
|
fecd69 |
+expect_pass "$test" "fs.protected_fifos = 2\\s+fs.protected_symlinks = 2\\s+fs.protected_hardlinks = 1"
|
|
|
fecd69 |
+
|
|
|
fecd69 |
+set test "sysctl write from file with slashes"
|
|
|
fecd69 |
+spawn $sysctl --dry-run -f ${topdir}testsuite/sysctl_slash_test.conf
|
|
|
fecd69 |
+expect_pass "$test" "kernel.hostname = procps-test"
|
|
|
fecd69 |
|
|
|
fecd69 |
set hostname_file "/proc/sys/kernel/hostname"
|
|
|
fecd69 |
if {[file exists ${hostname_file}]} {
|
|
|
fecd69 |
@@ -25,5 +33,5 @@ if {[file exists ${hostname_file}]} {
|
|
|
fecd69 |
expect_spawn_retval "$test" 0
|
|
|
fecd69 |
}
|
|
|
fecd69 |
} else {
|
|
|
fecd69 |
- unsupported "sysctl write: hostname file doe not exist"
|
|
|
fecd69 |
+ unsupported "sysctl write: hostname file does not exist"
|
|
|
fecd69 |
}
|