fix(command): return non-zero when child exec fails
Child exec failure paths were returning success, which masked command launch errors from callers. I switched the child-side failure exits to _exit(127) and added errno-specific logging so failures propagate with actionable diagnostics. Signed-off-by: Austin Horstman <khaneliman12@gmail.com>
This commit is contained in:
@@ -20,6 +20,8 @@ extern std::list<pid_t> reap;
|
|||||||
|
|
||||||
namespace waybar::util::command {
|
namespace waybar::util::command {
|
||||||
|
|
||||||
|
constexpr int kExecFailureExitCode = 127;
|
||||||
|
|
||||||
struct res {
|
struct res {
|
||||||
int exit_code;
|
int exit_code;
|
||||||
std::string out;
|
std::string out;
|
||||||
@@ -114,7 +116,9 @@ inline FILE* open(const std::string& cmd, int& pid, const std::string& output_na
|
|||||||
setenv("WAYBAR_OUTPUT_NAME", output_name.c_str(), 1);
|
setenv("WAYBAR_OUTPUT_NAME", output_name.c_str(), 1);
|
||||||
}
|
}
|
||||||
execlp("/bin/sh", "sh", "-c", cmd.c_str(), (char*)0);
|
execlp("/bin/sh", "sh", "-c", cmd.c_str(), (char*)0);
|
||||||
exit(0);
|
const int saved_errno = errno;
|
||||||
|
spdlog::error("execlp(/bin/sh) failed in open: {}", strerror(saved_errno));
|
||||||
|
_exit(kExecFailureExitCode);
|
||||||
} else {
|
} else {
|
||||||
::close(fd[1]);
|
::close(fd[1]);
|
||||||
}
|
}
|
||||||
@@ -162,7 +166,9 @@ inline int32_t forkExec(const std::string& cmd, const std::string& output_name)
|
|||||||
setenv("WAYBAR_OUTPUT_NAME", output_name.c_str(), 1);
|
setenv("WAYBAR_OUTPUT_NAME", output_name.c_str(), 1);
|
||||||
}
|
}
|
||||||
execl("/bin/sh", "sh", "-c", cmd.c_str(), (char*)0);
|
execl("/bin/sh", "sh", "-c", cmd.c_str(), (char*)0);
|
||||||
exit(0);
|
const int saved_errno = errno;
|
||||||
|
spdlog::error("execl(/bin/sh) failed in forkExec: {}", strerror(saved_errno));
|
||||||
|
_exit(kExecFailureExitCode);
|
||||||
} else {
|
} else {
|
||||||
reap_mtx.lock();
|
reap_mtx.lock();
|
||||||
reap.push_back(pid);
|
reap.push_back(pid);
|
||||||
|
|||||||
Reference in New Issue
Block a user