diff options
-rw-r--r-- | src/cli_new.c | 93 | ||||
-rw-r--r-- | src/cli_val.h | 9 | ||||
-rw-r--r-- | src/commit.c | 6 | ||||
-rw-r--r-- | src/delete.c | 4 | ||||
-rw-r--r-- | src/set.c | 4 |
5 files changed, 109 insertions, 7 deletions
diff --git a/src/cli_new.c b/src/cli_new.c index 2f2801d..abc87db 100644 --- a/src/cli_new.c +++ b/src/cli_new.c @@ -884,6 +884,8 @@ static int change_var_value(const char* var_reference,const char* value, int act return ret; } +int system_out(const char *command); + /**************************************************** check_syn: evaluate syntax tree; @@ -908,10 +910,8 @@ static boolean check_syn_func(vtw_node *cur,const char* func,int line) ret = check_syn(cur->vtw_node_left); if (ret <= 0){ if (expand_string(cur->vtw_node_right->vtw_node_string) == VTWERR_OK) { - fprintf(stderr, exe_string); - fprintf(stderr, "\n"); - printf(exe_string); - printf("\n"); + fprintf(out_stream, exe_string); + fprintf(out_stream, "\n"); } } return ret; @@ -967,7 +967,7 @@ static boolean check_syn_func(vtw_node *cur,const char* func,int line) set_at_string(save_at); return FALSE; } - ret = system(exe_string); + ret = system_out(exe_string); if (ret) { set_at_string(save_at); return FALSE; @@ -981,7 +981,7 @@ static boolean check_syn_func(vtw_node *cur,const char* func,int line) if (status != VTWERR_OK) { return FALSE; } - ret = system(exe_string); + ret = system_out(exe_string); return !ret; case PATTERN_OP: /* left to var, right to pattern */ @@ -1935,4 +1935,85 @@ static int set_reference_environment(const char* var_reference, } } +/*** output ***/ + +int out_fd = -1; +FILE *out_stream = NULL; + +int err_fd = -1; +FILE *err_stream = NULL; +int new_out_fd = -1; +int new_err_fd = -1; + +int +initialize_output() +{ + if ((out_fd = dup(STDOUT_FILENO)) == -1) { + return -1; + } + if ((out_stream = fdopen(out_fd, "a")) == NULL) { + return -1; + } + if ((err_fd = dup(STDOUT_FILENO)) == -1) { + return -1; + } + if ((err_stream = fdopen(err_fd, "a")) == NULL) { + return -1; + } + + new_out_fd = open(LOGFILE_STDOUT, O_WRONLY | O_CREAT, 0660); + new_err_fd = open(LOGFILE_STDERR, O_WRONLY | O_CREAT, 0660); + if (new_out_fd == -1 || new_err_fd == -1) { + return -1; + } + if ((lseek(new_out_fd, 0, SEEK_END) == ((off_t) -1)) + || (lseek(new_err_fd, 0, SEEK_END) == ((off_t) -1))) { + return -1; + } + if ((dup2(new_out_fd, STDOUT_FILENO) == -1) + || (dup2(new_err_fd, STDERR_FILENO) == -1)) { + return -1; + } + + return 0; +} + +int +redirect_output() +{ + if ((dup2(new_out_fd, STDOUT_FILENO) == -1) + || (dup2(new_err_fd, STDERR_FILENO) == -1)) { + return -1; + } + return 0; +} + +int +restore_output() +{ + if ((dup2(out_fd, STDOUT_FILENO) == -1) + || (dup2(err_fd, STDERR_FILENO) == -1)) { + return -1; + } + return 0; +} + +/* system_out: + * call system() with output re-enabled. + * output is again redirected before returning from here. + */ +int +system_out(const char *command) +{ + int ret = -1; + if (restore_output() == -1) { + return -1; + } + ret = system(command); + if (redirect_output() == -1) { + return -1; + } + return ret; +} + /**********************************************************/ diff --git a/src/cli_val.h b/src/cli_val.h index 8a98a88..6ccfde2 100644 --- a/src/cli_val.h +++ b/src/cli_val.h @@ -203,4 +203,13 @@ extern boolean get_config_lock(const char* adirp, const char* lock_name); #define INTERNAL internal_error(__LINE__, __FILE__) +/*** output ***/ +#define LOGFILE_STDOUT "/tmp/cfg-stdout.log" +#define LOGFILE_STDERR "/tmp/cfg-stderr.log" + +extern int out_fd; +extern FILE *out_stream; + +extern int initialize_output(); + #endif diff --git a/src/commit.c b/src/commit.c index a136b58..a8edbaf 100644 --- a/src/commit.c +++ b/src/commit.c @@ -257,7 +257,11 @@ int main(int argc, char **argv) struct stat statbuf; int st; boolean update_pending = FALSE; - + + if (initialize_output() == -1) { + exit(-1); + } + set_in_commit(TRUE); dump_log( argc, argv); init_paths(TRUE); diff --git a/src/delete.c b/src/delete.c index a825a22..5981923 100644 --- a/src/delete.c +++ b/src/delete.c @@ -70,6 +70,10 @@ int main(int argc, char **argv) char *cp, *delp, *endp; boolean do_umount; + if (initialize_output() == -1) { + exit(-1); + } + if (argc < 2) { fprintf(stderr, "Need to specify the config node to delete\n"); exit(1); @@ -94,6 +94,10 @@ int main(int argc, char **argv) boolean need_mod = FALSE, not_new = FALSE; boolean empty_val = FALSE; + if (initialize_output() == -1) { + exit(-1); + } + dump_log( argc, argv); init_edit(); last_tag = FALSE; |