X-Git-Url: https://plomlompom.com/repos/index.html?a=blobdiff_plain;f=src%2Fclient%2Fmain.c;h=3e3bbdd28f7c6b6a83a2ac801d26caa2967eac92;hb=024b404c0db59dc6651b1c8f3d379c2797654fdf;hp=4fb6b3bce7b282e9ba36040b19fa377946b3abd4;hpb=bdd8f79ade82ef1a7445580fa61a53fd1a5311db;p=plomrogue
diff --git a/src/client/main.c b/src/client/main.c
index 4fb6b3b..3e3bbdd 100644
--- a/src/client/main.c
+++ b/src/client/main.c
@@ -1,12 +1,15 @@
/* main.c */
+#include /* keypad() */
+#include /* struct sigaction, sigaction() */
#include /* exit() */
-#include "../common/rexit.h" /* set_cleanup_func() */
-#include "cleanup.h" /* cleanup() */
+#include /* memset() */
+#include "../common/rexit.h" /* set_cleanup_func(), exit_trouble() */
+#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() */
-#include "windows.h" /* init_wmeta_and_ncurses(); */
+#include "misc.h" /* load_interface_conf(), winch_called() */
+#include "windows.h" /* struct Win, winch_called() */
#include "world.h" /* struct World */
@@ -15,20 +18,35 @@ struct World world;
-int main()
+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";
+
+ /* Parse command line arguments. */
+ obey_argv(argc, argv);
/* So error exits also go through the client's cleanup() function. */
set_cleanup_func(cleanup);
/* Initialize the whole interface. */
- init_wmeta_and_ncurses();
- keypad(world.wmeta.screen, TRUE);
+ world.windb.t_screen = initscr();
+ set_cleanup_flag(CLEANUP_NCURSES);
+ noecho();
+ curs_set(0);
+ 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. */
+ /* Set handler for terminal window resizing. */
+ struct sigaction act;
+ memset(&act, 0, sizeof(act));
+ act.sa_handler = &winch_called;
+ exit_trouble(sigaction(SIGWINCH, &act, NULL), f_name, "sigaction()");
+
/* This is where most everything happens. */
char * quit_msg = io_loop();