static char rcsid[] = "@(#)$Id: elmterminal.c,v 1.19 2006/04/09 07:37:30 hurtta Exp $"; /****************************************************************************** * The Elm (ME+) Mail System - $Revision: 1.19 $ $State: Exp $ * * Author: Kari Hurtta (was hurtta+elm@ozone.FMI.FI) *****************************************************************************/ #include "elmutil.h" #include "s_me.h" #include "s_elm.h" #include "misclib.h" #include "reghelper.h" extern char *optarg; extern int optind; char * program_name = "elmterminal"; int register_fd = -1; char * register_module = NULL; int main P_((int argc, char *argv[])); int main(argc, argv) int argc; char *argv[]; { int err = 0; int c; int global = 0; struct terminal_map_item * MAP = NULL; char *targetfile = NULL; int config_merge = 0; #if DEBUG init_debugfile("ELMTERMINAL"); #endif locale_init(); REGHELPER_INIT(argv[0]); user_init(); init_misclib(); init_defaults(); while ((c = getopt(argc, argv, "Gd:w:c")) != EOF) { switch(c) { case 'G': global++; break; case 'c': config_merge++; break; case 'd' : #if DEBUG set_debugging(optarg); #else lib_error(CATGETS(elm_msg_cat, ElmSet, ElmArgsIngoringDebug, "Warning: system created without debugging enabled - request ignored\n")); #endif break; case 'w' : targetfile = optarg; if (0 != access(targetfile,WRITE_ACCESS)) { int errcode = errno; if (errcode != ENOENT) { lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotWriteable, "File %.50s is not writeable: %s"), targetfile, error_description(errcode)); err++; goto fail; } } break; case '?': err = 1; goto fail; } } elm_sfprintf(version_buff, sizeof version_buff, FRM("%s PL%s"), VERSION, PATCHLEVEL); #ifdef DEBUG { int d = panic_dprint("\n\ ======================================================\n\ Debug output of the ELMTERMINAL program (version %s).\n", version_buff); #if 0 if (d >= 50) { panic_dprint("WARNING: Edit manually out sensitive information from that file!\n"); lower_prompt("WARNING: Debug file may include passwords -- edit it!"); sleep(5+sleepmsg); } #endif } #endif if (!global) read_rc_file(0); else post_init_check(0); if (optind < argc) { int errcount = 0; MAP = load_terminal_map(argv[optind],&errcount); if (!MAP || errcount) { err = 1; goto fail; } } if (config_merge) { if (!MAP) { lib_error(CATGETS(elm_msg_cat, MeSet, MeConfigMergeMap, "Config merge (-c) requires map as argument")); err++; goto fail; } if (targetfile) { lib_error(CATGETS(elm_msg_cat, MeSet, MeConfigMergeNoW, "Config merge (-c) Can not used with -w")); err++; goto fail; } if (global) { change_terminal_map(& system_terminal_map, MAP); free_terminal_map(&MAP); MAP = system_terminal_map; targetfile = system_terminal_info; } else { change_terminal_map(& user_terminal_map, MAP); free_terminal_map(&MAP); MAP = user_terminal_map; targetfile = user_terminal_info; } if (0 != access(targetfile,WRITE_ACCESS)) { int errcode = errno; if (errcode != ENOENT) { lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotWriteable, "File %.50s is not writeable: %s"), targetfile, error_description(errcode)); err++; goto fail; } } } if (!MAP) { if (global) MAP = system_terminal_map; else MAP = user_terminal_map; } if (targetfile) { char * tmp = elm_message(FRM("%s.N"),targetfile); int errcode = can_open(tmp,"w"); FILE *f; if (errcode) { lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotWriteable, "File %.50s is not writeable: %s"), tmp, error_description(errcode)); err++; free(tmp); goto fail; } f = fopen(tmp,"w"); if (!f) { int errcode = errno; lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotWriteable, "File %.50s is not writeable: %s"), tmp, error_description(errcode)); err++; free(tmp); goto fail; } dump_terminal_map(f,MAP); if (EOF == fclose(f)) { int errcode = errno; lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotWriteable, "File %.50s is not writeable: %s"), tmp, error_description(errcode)); err++; free(tmp); goto fail; } if (0 != rename(tmp,targetfile)) { int errcode = errno; lib_error(CATGETS(elm_msg_cat, MeSet, MeFileNotRenamed, "Failed to rename temporary file to %.50s: %.30s"), targetfile, error_description(errcode)); err++; free(tmp); goto fail; } log_config(targetfile); free(tmp); } else dump_terminal_map(stdout,MAP); fail: if (err) lib_error(CATGETS(elm_msg_cat, MeSet, MeProgFailed, "%s failed; exit code=%d"), argv[0],err); return err; } /* * Local Variables: * mode:c * c-basic-offset:4 * buffer-file-coding-system: iso-8859-1 * End: */