diff options
Diffstat (limited to 'ui/main.c')
| -rw-r--r-- | ui/main.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/ui/main.c b/ui/main.c new file mode 100644 index 0000000..d6d50c4 --- /dev/null +++ b/ui/main.c @@ -0,0 +1,52 @@ +#include "gio/gio.h" +#include <gtk/gtk.h> + +static void say_hi(GtkWidget *widget, gpointer data) +{ + g_print("Hello, world!\n"); +} + +static void activate(GtkApplication *app, gpointer up) +{ + GtkBuilder *builder = gtk_builder_new_from_resource("/dev/figboot/vaclaunch/progress.ui"); + GObject *window = gtk_builder_get_object(builder, "window"); + + gtk_window_set_application(GTK_WINDOW(window), app); + + g_signal_connect(gtk_builder_get_object(builder, "btn-cancel"), "clicked", G_CALLBACK(say_hi), NULL); + + gtk_window_present(GTK_WINDOW(window)); + g_object_unref(builder); +} + +static void do_work(GTask *task, GObject *src, gpointer task_data, GCancellable *cancellable) +{ + /* do work */ +} + +static GAsyncResult *do_task_async(GObject *self, GAsyncReadyCallback cb, gpointer user_data) +{ + GTask *task = g_task_new(self, NULL, cb, user_data); + + g_task_run_in_thread(task, (GTaskThreadFunc)do_work); + return G_ASYNC_RESULT(task); +} + +static void *do_task_finish(GObject *self, GAsyncResult *res, GError **perror) +{ + g_return_val_if_fail(g_task_is_valid(res, self), NULL); + return g_task_propagate_pointer(G_TASK(res), perror); +} + +int main(int argc, char **argv) +{ + GtkApplication *app; + int status; + + app = gtk_application_new("dev.figboot.vaclaunch", G_APPLICATION_DEFAULT_FLAGS); + g_signal_connect(app, "activate", G_CALLBACK(activate), NULL); + status = g_application_run(G_APPLICATION(app), argc, argv); + g_object_unref(app); + + return status; +} |
