From af1a266670d040d2f4083ff309d732d648afba2a Mon Sep 17 00:00:00 2001 From: Angelos Mouzakitis Date: Tue, 10 Oct 2023 14:33:42 +0000 Subject: Add submodule dependency files Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec --- .../test cases/vala/5 target glib/GLib.Thread.vala | 43 ++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 meson/test cases/vala/5 target glib/GLib.Thread.vala (limited to 'meson/test cases/vala/5 target glib/GLib.Thread.vala') diff --git a/meson/test cases/vala/5 target glib/GLib.Thread.vala b/meson/test cases/vala/5 target glib/GLib.Thread.vala new file mode 100644 index 000000000..701882180 --- /dev/null +++ b/meson/test cases/vala/5 target glib/GLib.Thread.vala @@ -0,0 +1,43 @@ +extern int get_ret_code (); + +public class MyThread : Object { + public int x_times { get; private set; } + + public MyThread (int times) { + this.x_times = times; + } + + public int run () { + for (int i = 0; i < this.x_times; i++) { + stdout.printf ("ping! %d/%d\n", i + 1, this.x_times); + Thread.usleep (10000); + } + + // return & exit have the same effect + Thread.exit (get_ret_code ()); + return 43; + } +} + +public static int main (string[] args) { + // Check whether threads are supported: + if (Thread.supported () == false) { + stderr.printf ("Threads are not supported!\n"); + return -1; + } + + try { + // Start a thread: + MyThread my_thread = new MyThread (10); + Thread thread = new Thread.try ("My fst. thread", my_thread.run); + + // Wait until thread finishes: + int result = thread.join (); + // Output: `Thread stopped! Return value: 42` + stdout.printf ("Thread stopped! Return value: %d\n", result); + } catch (Error e) { + stdout.printf ("Error: %s\n", e.message); + } + + return 0; +} -- cgit 1.2.3-korg