X-Git-Url: https://plomlompom.com/repos/test.html?a=blobdiff_plain;f=src%2Fclient%2Fmain.c;h=a0cb82c6b93f22e8db4313661b729c9d52bdf555;hb=be8c57c7e1de5962913f849b862faae01bead264;hp=61c53b8f7d1861ad28c8799c7bd3b6dc2d85d7e9;hpb=fb9b40f0535b28b37b64983240c4b78e74ee9a2c;p=plomrogue
diff --git a/src/client/main.c b/src/client/main.c
index 61c53b8..a0cb82c 100644
--- a/src/client/main.c
+++ b/src/client/main.c
@@ -2,13 +2,18 @@
#include /* keypad() */
#include /* struct sigaction, sigaction() */
+#include /* NULL */
#include /* exit() */
#include /* memset() */
-#include "../common/rexit.h" /* set_cleanup_func(), exit_trouble() */
+#include /* access() */
+#include "../common/err_try_fgets.h" /* set_err_try_fgets_delim() */
+#include "../common/readwrite.h" /* try_fopen() */
+#include "../common/rexit.h" /* set_cleanup_func(), exit_trouble(),exit_err() */
#include "cleanup.h" /* cleanup(), set_cleanup_flag() */
#include "command_db.h" /* init_command_db() */
-#include "io.h" /* io_loop(), try_send() */
-#include "misc.h" /* load_interface_conf(), winch_called() */
+#include "interface_conf.h" /* load_interface_conf(), obey_argv() */
+#include "io.h" /* io_loop() */
+#include "windows.h" /* winch_called() */
#include "world.h" /* struct World */
@@ -21,9 +26,14 @@ int main(int argc, char * argv[])
{
char * f_name = "main()";
- /* Declare hard-coded paths here. */
- world.path_server_in = "server/in";
- world.path_interface_conf = "confclient/interface_conf";
+ /* Declare hard-coded paths and values here. */
+ world.path_commands = "confclient/commands";
+ world.path_interface = "confclient/interface_conf";
+ world.winDB.legal_ids = "012ciklm";
+ world.delim = "%\n";
+ set_err_try_fgets_delim(world.delim);
+ char * path_server_in = "server/in";
+ char * path_server_out = "server/out";
/* Parse command line arguments. */
obey_argv(argc, argv);
@@ -31,12 +41,16 @@ int main(int argc, char * argv[])
/* So error exits also go through the client's cleanup() function. */
set_cleanup_func(cleanup);
+ /* Check existence of config files. */
+ exit_err(access(world.path_commands, F_OK), "No commands config file.");
+ exit_err(access(world.path_interface, F_OK), "No interface config file.");
+
/* Initialize the whole interface. */
- world.wins.screen = initscr();
+ world.winDB.t_screen = initscr();
set_cleanup_flag(CLEANUP_NCURSES);
noecho();
curs_set(0);
- keypad(world.wins.screen, TRUE);
+ keypad(world.winDB.t_screen, TRUE);
init_command_db(); /* The command DB needs to be initialized before */
load_interface_conf(); /* the interface, whose keybindings depend on it. */
@@ -46,6 +60,13 @@ int main(int argc, char * argv[])
act.sa_handler = &winch_called;
exit_trouble(sigaction(SIGWINCH, &act, NULL), f_name, "sigaction()");
+ /* Open file streams for communicating with the server. */
+ exit_err(access(path_server_in, F_OK), "No server input file found.");
+ world.file_server_in = try_fopen(path_server_in, "a", f_name);
+ set_cleanup_flag(CLEANUP_SERVER_IN);
+ world.file_server_out = try_fopen(path_server_out, "r", f_name);
+ set_cleanup_flag(CLEANUP_SERVER_OUT);
+
/* This is where most everything happens. */
char * quit_msg = io_loop();