From 154f94d1fd2de8f6510bfebba848a24c60b1ba8b Mon Sep 17 00:00:00 2001 From: bigfoot547 Date: Sat, 24 Jan 2026 16:04:56 -0600 Subject: gtk stuff --- ui/main.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 ui/main.c (limited to 'ui/main.c') 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 + +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; +} -- cgit v1.2.3-70-g09d2