diff options
| author | 2026-01-24 16:04:56 -0600 | |
|---|---|---|
| committer | 2026-01-24 16:04:56 -0600 | |
| commit | 154f94d1fd2de8f6510bfebba848a24c60b1ba8b (patch) | |
| tree | 072bf7b9bb6f3599f54cf200e4d9eedde783c34d /ui | |
| parent | endian functions (diff) | |
gtk stuffHEADmasterbefore-glib
Diffstat (limited to 'ui')
| -rw-r--r-- | ui/main.c | 52 | ||||
| -rw-r--r-- | ui/meson.build | 8 | ||||
| -rw-r--r-- | ui/resources/main.ui | 22 | ||||
| -rw-r--r-- | ui/resources/meson.build | 5 | ||||
| -rw-r--r-- | ui/resources/progress.ui | 37 | ||||
| -rw-r--r-- | ui/resources/vaclaunch.gresource.xml | 6 |
6 files changed, 130 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; +} diff --git a/ui/meson.build b/ui/meson.build new file mode 100644 index 0000000..c1c4cb8 --- /dev/null +++ b/ui/meson.build @@ -0,0 +1,8 @@ +gtk4_dep = dependency('gtk4', required : true) + +subdir('resources') + +executable('vlui', files('main.c'), main_res, + link_with : [ vaclaunch_libs.get_shared_lib() ], + dependencies : [ curl_dep, jansson_dep, gtk4_dep ], + include_directories : proj_inc) diff --git a/ui/resources/main.ui b/ui/resources/main.ui new file mode 100644 index 0000000..4f4315d --- /dev/null +++ b/ui/resources/main.ui @@ -0,0 +1,22 @@ +<?xml version='1.0' encoding='UTF-8'?> +<!-- Created with Cambalache 0.96.3 --> +<interface> + <!-- interface-name main.ui --> + <requires lib="gtk" version="4.0"/> + <object class="GtkApplicationWindow" id="window"> + <child> + <object class="GtkBox"> + <property name="orientation">vertical</property> + <child> + <object class="GtkActionBar"> + <child> + <object class="GtkButton"> + <property name="label">Cancel</property> + </object> + </child> + </object> + </child> + </object> + </child> + </object> +</interface> diff --git a/ui/resources/meson.build b/ui/resources/meson.build new file mode 100644 index 0000000..0642a3f --- /dev/null +++ b/ui/resources/meson.build @@ -0,0 +1,5 @@ +gnome = import('gnome') + +main_res = gnome.compile_resources('vl-res', + files('vaclaunch.gresource.xml'), + c_name : 'vl') diff --git a/ui/resources/progress.ui b/ui/resources/progress.ui new file mode 100644 index 0000000..e49d9e0 --- /dev/null +++ b/ui/resources/progress.ui @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <requires lib="gtk" version="4.0"/> + <object class="GtkWindow" id="window"> + <property name="decorated">false</property> + <property name="modal">true</property> + <property name="resizable">false</property> + <property name="halign">center</property> + <property name="valign">center</property> + <child> + <object class="GtkBox"> + <property name="orientation">vertical</property> + <child> + <object class="GtkProgressBar" id="progress"> + <property name="width-request">250</property> + <property name="text">Doing operation</property> + <property name="show-text">true</property> + <property name="fraction">0.25</property> + <property name="margin-top">20</property> + <property name="margin-bottom">20</property> + <property name="margin-start">20</property> + <property name="margin-end">20</property> + </object> + </child> + <child> + <object class="GtkActionBar"> + <child type="end"> + <object class="GtkButton" id="btn-cancel"> + <property name="label">Cancel</property> + </object> + </child> + </object> + </child> + </object> + </child> + </object> +</interface> diff --git a/ui/resources/vaclaunch.gresource.xml b/ui/resources/vaclaunch.gresource.xml new file mode 100644 index 0000000..10c76d5 --- /dev/null +++ b/ui/resources/vaclaunch.gresource.xml @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="UTF-8"?> +<gresources> + <gresource prefix="/dev/figboot/vaclaunch"> + <file compressed="true" preprocess="xml-stripblanks">progress.ui</file> + </gresource> +</gresources> |
