projects
/
rodin
/
chimara.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Added and updated Zarf's Glulxercise unit tests
[rodin/chimara.git]
/
tests
/
glulxercise.c
diff --git
a/tests/glulxercise.c
b/tests/glulxercise.c
index 6d4b21fecce61d4efd35946a4e0aa56827be7f92..3f3b3933bcdef15ca33a4c0ee6e41cf7781fac51 100644
(file)
--- a/
tests/glulxercise.c
+++ b/
tests/glulxercise.c
@@
-1,7
+1,6
@@
#include <glib.h>
#include <libchimara/chimara-glk.h>
#include <libchimara/chimara-if.h>
#include <glib.h>
#include <libchimara/chimara-glk.h>
#include <libchimara/chimara-if.h>
-#include "error.h"
#define LOAD_WIDGET(name) GTK_WIDGET(gtk_builder_get_object(builder, name))
#define LOAD_WIDGET(name) GTK_WIDGET(gtk_builder_get_object(builder, name))
@@
-31,12
+30,13
@@
on_go_clicked(GtkButton *go, Widgets *w)
gchar *fullpath = g_build_filename(PACKAGE_SRC_DIR, filename, NULL);
if( !chimara_if_run_game(CHIMARA_IF(w->interp), fullpath, &error) )
gchar *fullpath = g_build_filename(PACKAGE_SRC_DIR, filename, NULL);
if( !chimara_if_run_game(CHIMARA_IF(w->interp), fullpath, &error) )
- {
- error_dialog(GTK_WINDOW(w->window), error, "Error starting Glk library: ");
- gtk_main_quit();
- }
+ g_error("Error starting Glk library: %s", error->message);
g_free(fullpath);
g_free(fullpath);
+}
+void
+on_interp_started(ChimaraGlk *glk, Widgets *w)
+{
gtk_widget_set_sensitive(w->go, FALSE);
gtk_widget_set_sensitive(w->stop, TRUE);
gtk_widget_set_sensitive(w->test_picker, FALSE);
gtk_widget_set_sensitive(w->go, FALSE);
gtk_widget_set_sensitive(w->stop, TRUE);
gtk_widget_set_sensitive(w->test_picker, FALSE);
@@
-47,7
+47,11
@@
on_stop_clicked(GtkButton *stop, Widgets *w)
{
chimara_glk_stop( CHIMARA_GLK(w->interp) );
chimara_glk_wait( CHIMARA_GLK(w->interp) );
{
chimara_glk_stop( CHIMARA_GLK(w->interp) );
chimara_glk_wait( CHIMARA_GLK(w->interp) );
+}
+void
+on_interp_stopped(ChimaraGlk *glk, Widgets *w)
+{
gtk_widget_set_sensitive(w->stop, FALSE);
gtk_widget_set_sensitive(w->go, TRUE);
gtk_widget_set_sensitive(w->test_picker, TRUE);
gtk_widget_set_sensitive(w->stop, FALSE);
gtk_widget_set_sensitive(w->go, TRUE);
gtk_widget_set_sensitive(w->test_picker, TRUE);
@@
-79,10
+83,7
@@
main(int argc, char *argv[])
GtkBuilder *builder = gtk_builder_new();
if(!gtk_builder_add_from_file(builder, PACKAGE_SRC_DIR "/glulxercise.ui", &error))
GtkBuilder *builder = gtk_builder_new();
if(!gtk_builder_add_from_file(builder, PACKAGE_SRC_DIR "/glulxercise.ui", &error))
- {
- error_dialog(NULL, error, "Failed to build interface: ");
- return 1;
- }
+ g_error("Failed to build interface: %s", error->message);
Widgets *w = g_slice_new0(Widgets);
w->window = LOAD_WIDGET("window");
Widgets *w = g_slice_new0(Widgets);
w->window = LOAD_WIDGET("window");
@@
-92,8
+93,11
@@
main(int argc, char *argv[])
w->go = LOAD_WIDGET("go");
w->stop = LOAD_WIDGET("stop");
w->interp = chimara_if_new();
w->go = LOAD_WIDGET("go");
w->stop = LOAD_WIDGET("stop");
w->interp = chimara_if_new();
+ gtk_widget_set_size_request(w->interp, 500, 600);
gtk_box_pack_end_defaults(GTK_BOX(vbox), w->interp);
gtk_builder_connect_signals(builder, w);
gtk_box_pack_end_defaults(GTK_BOX(vbox), w->interp);
gtk_builder_connect_signals(builder, w);
+ g_signal_connect(w->interp, "started", G_CALLBACK(on_interp_started), w);
+ g_signal_connect(w->interp, "stopped", G_CALLBACK(on_interp_stopped), w);
gtk_widget_show_all(w->window);
gdk_threads_enter();
gtk_widget_show_all(w->window);
gdk_threads_enter();