* parse kernel cmdline option for capability bset
-* journalctl /dev/sda, journalctl /usr/bin/httpd, journalctl --device=b12:8 (--device=n12, --device=+usb:1-1)
+* journalctl /dev/sda, journalctl --device=b12:8 (--device=n12, --device=+usb:1-1)
* make use of /sys/power/wake_lock in inhibitors
#include <sys/poll.h>
#include <time.h>
#include <getopt.h>
+#include <sys/stat.h>
#include <systemd/sd-journal.h>
#include "pager.h"
#include "logs-show.h"
+#define SD_JOURNALCTL_EXE "_EXE="
+
static OutputMode arg_output = OUTPUT_SHORT;
static bool arg_follow = false;
static bool arg_show_all = false;
sd_journal *j = NULL;
unsigned line = 0;
bool need_seek = false;
+ struct stat st;
+ char* journal_exe_buff;
log_parse_environment();
log_open();
}
for (i = optind; i < argc; i++) {
- r = sd_journal_add_match(j, argv[i], strlen(argv[i]));
+ if (strchr(argv[i], '=')) {
+ r = sd_journal_add_match(j, argv[i], strlen(argv[i]));
+ } else {
+ if (stat(argv[i], &st) < 0) {
+ log_error("Failed to add match: %s", strerror(-r));
+ goto finish; /* maybe try sd_journal_add_match() when stat() fails,
+ * even thought we know there is no '=' ? */
+ } else if (S_ISREG(st.st_mode) &&
+ S_IXUSR & st.st_mode) {
+ journal_exe_buff = malloc(strlen(SD_JOURNALCTL_EXE) + strlen(argv[i]) + 1);
+ journal_exe_buff = strcpy(journal_exe_buff, SD_JOURNALCTL_EXE);
+ strncat(journal_exe_buff, argv[i], strlen(argv[i]));
+ r = sd_journal_add_match(j, journal_exe_buff, strlen(journal_exe_buff));
+ free(journal_exe_buff);
+ } else {
+ log_error("File is not a regular file or is not executable: %s", argv[i]);
+ goto finish;
+ }
+ }
if (r < 0) {
log_error("Failed to add match: %s", strerror(-r));
goto finish;