X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=tests%2Fmain.c;h=82c92bf1a073a3fc474efa32e7edcea1b808203c;hb=57ceef742182d6f0d1f7844256863a37c2d80d6a;hp=9ed6158f2245e49593f63e87e820ec33a8cf463d;hpb=0619b371ff5c35ce062557c9ecf478379020673b;p=rodin%2Fchimara.git diff --git a/tests/main.c b/tests/main.c index 9ed6158..82c92bf 100644 --- a/tests/main.c +++ b/tests/main.c @@ -40,9 +40,9 @@ #include #include -#include "callbacks.h" #include "error.h" #include +#include /* Global pointers to widgets */ GtkBuilder *builder = NULL; @@ -63,21 +63,12 @@ on_stopped(ChimaraGlk *glk) } static void -on_char_input(ChimaraGlk *glk, guint32 window_rock, guint keysym) +on_command(ChimaraGlk *glk, gchar *input, gchar *response) { - g_printerr("Character input in window %d: key %d\n", window_rock, keysym); -} - -static void -on_line_input(ChimaraGlk *glk, guint32 window_rock, gchar *text) -{ - g_printerr("Line input in window %d: '%s'\n", window_rock, text); -} - -static void -on_text_buffer_output(ChimaraGlk *glk, guint32 window_rock, gchar *text) -{ - g_printerr("Text buffer output in window %d: '%s'\n", window_rock, text); + gchar *ellipsized = g_strdelimit(g_strndup(response, 20), "\n", ' '); + g_print("%s - %s%s\n", input, ellipsized, + (strlen(ellipsized) < strlen(response))? "..." : ""); + g_free(ellipsized); } static GObject * @@ -97,7 +88,7 @@ create_window(void) GError *error = NULL; builder = gtk_builder_new(); - if( !gtk_builder_add_from_file(builder, "chimara.ui", &error) ) { + if( !gtk_builder_add_from_file(builder, PACKAGE_SRC_DIR "/chimara.ui", &error) ) { error_dialog(NULL, error, "Error while building interface: "); return; } @@ -113,6 +104,9 @@ create_window(void) "open", "F7", "save", NULL, /* NULL means use stock accelerator */ "quit", NULL, + "hint", "", + "char_input", "", + "char_input2", "", NULL }; const gchar **ptr; @@ -120,22 +114,24 @@ create_window(void) gtk_action_group_add_action_with_accel(actiongroup, GTK_ACTION(load_object(ptr[0])), ptr[1]); uimanager = gtk_ui_manager_new(); - if( !gtk_ui_manager_add_ui_from_file(uimanager, "chimara.menus", &error) ) { + if( !gtk_ui_manager_add_ui_from_file(uimanager, PACKAGE_SRC_DIR "/chimara.menus", &error) ) { error_dialog(NULL, error, "Error while building interface: "); return; } - gtk_builder_connect_signals(builder, NULL); - - glk = chimara_glk_new(); - g_object_set(glk, "border-width", 6, "spacing", 6, NULL); + glk = chimara_if_new(); + //chimara_if_set_preferred_interpreter( CHIMARA_IF(glk), CHIMARA_IF_FORMAT_Z8, CHIMARA_IF_INTERPRETER_NITFOL); + + g_object_set(glk, + "border-width", 6, + "spacing", 6, + "ignore-errors", TRUE, + NULL); chimara_glk_set_default_font_string(CHIMARA_GLK(glk), "Serif 12"); chimara_glk_set_monospace_font_string(CHIMARA_GLK(glk), "Monospace 12"); g_signal_connect(glk, "started", G_CALLBACK(on_started), NULL); g_signal_connect(glk, "stopped", G_CALLBACK(on_stopped), NULL); - g_signal_connect(glk, "char-input", G_CALLBACK(on_char_input), NULL); - g_signal_connect(glk, "line-input", G_CALLBACK(on_line_input), NULL); - g_signal_connect(glk, "text-buffer-output", G_CALLBACK(on_text_buffer_output), NULL); + g_signal_connect(glk, "command", G_CALLBACK(on_command), NULL); GtkBox *vbox = GTK_BOX( gtk_builder_get_object(builder, "vbox") ); if(vbox == NULL) @@ -151,6 +147,8 @@ create_window(void) gtk_box_pack_end(vbox, glk, TRUE, TRUE, 0); gtk_box_pack_start(vbox, menubar, FALSE, FALSE, 0); gtk_box_pack_start(vbox, toolbar, FALSE, FALSE, 0); + + gtk_builder_connect_signals(builder, glk); } int @@ -175,10 +173,17 @@ main(int argc, char *argv[]) g_object_unref( G_OBJECT(builder) ); g_object_unref( G_OBJECT(uimanager) ); - if( !chimara_glk_run(CHIMARA_GLK(glk), "../interpreters/frotz/.libs/frotz.so", argc, argv, &error) ) { + if(argc < 2) { + error_dialog(GTK_WINDOW(window), NULL, "Must provide a game file"); + return 1; + } + + if( !chimara_if_run_game(CHIMARA_IF(glk), argv[1], &error) ) { error_dialog(GTK_WINDOW(window), error, "Error starting Glk library: "); return 1; } + //chimara_glk_run( CHIMARA_GLK(glk), ".libs/multiwin.so", argc, argv, NULL); + gdk_threads_enter(); gtk_main();