summaryrefslogtreecommitdiffstats
path: root/ui/main.c
diff options
context:
space:
mode:
authorLibravatar bigfoot547 <bigfoot@figboot.dev>2026-01-24 16:04:56 -0600
committerLibravatar bigfoot547 <bigfoot@figboot.dev>2026-01-24 16:04:56 -0600
commit154f94d1fd2de8f6510bfebba848a24c60b1ba8b (patch)
tree072bf7b9bb6f3599f54cf200e4d9eedde783c34d /ui/main.c
parentendian functions (diff)
Diffstat (limited to 'ui/main.c')
-rw-r--r--ui/main.c52
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;
+}