chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
everywhere: port everything to sigprocmask_many() and friends
[elogind.git]
/
src
/
shared
/
pager.c
diff --git
a/src/shared/pager.c
b/src/shared/pager.c
index 58b62fdccfab66cd430c5bb304ef4c7dbd3cc2fd..13f03e798b2b83ec030941d1918ac3ab02e25a38 100644
(file)
--- a/
src/shared/pager.c
+++ b/
src/shared/pager.c
@@
-30,6
+30,7
@@
#include "process-util.h"
#include "macro.h"
#include "terminal-util.h"
#include "process-util.h"
#include "macro.h"
#include "terminal-util.h"
+#include "signal-util.h"
static pid_t pager_pid = 0;
static pid_t pager_pid = 0;
@@
-85,6
+86,9
@@
int pager_open(bool jump_to_end) {
if (pager_pid == 0) {
const char* less_opts;
if (pager_pid == 0) {
const char* less_opts;
+ (void) reset_all_signal_handlers();
+ (void) reset_signal_mask();
+
dup2(fd[0], STDIN_FILENO);
safe_close_pair(fd);
dup2(fd[0], STDIN_FILENO);
safe_close_pair(fd);
@@
-178,6
+182,10
@@
int show_man_page(const char *desc, bool null_stdio) {
if (pid == 0) {
/* Child */
if (pid == 0) {
/* Child */
+
+ (void) reset_all_signal_handlers();
+ (void) reset_signal_mask();
+
if (null_stdio) {
r = make_null_stdio();
if (r < 0) {
if (null_stdio) {
r = make_null_stdio();
if (r < 0) {