diff options
| author | Mitja Felicijan <mitja.felicijan@gmail.com> | 2024-09-15 07:54:55 +0200 |
|---|---|---|
| committer | Mitja Felicijan <mitja.felicijan@gmail.com> | 2024-09-15 07:54:55 +0200 |
| commit | c81c7b573aa98953ed77fdf8b318e67d3cbe267a (patch) | |
| tree | 245549840b9412078da32f7e946902dbe9f95c44 /zig-x11 | |
| parent | 12d299f552a5aa8b6ea711dbe67805c4a5aab10d (diff) | |
| download | probe-c81c7b573aa98953ed77fdf8b318e67d3cbe267a.tar.gz | |
Added Zig and X11 example for creating simple Window
Diffstat (limited to 'zig-x11')
| -rw-r--r-- | zig-x11/.clang-format | 4 | ||||
| -rw-r--r-- | zig-x11/Makefile | 8 | ||||
| -rw-r--r-- | zig-x11/main.zig | 32 | ||||
| -rw-r--r-- | zig-x11/window.c | 15 |
4 files changed, 59 insertions, 0 deletions
diff --git a/zig-x11/.clang-format b/zig-x11/.clang-format new file mode 100644 index 0000000..84ac618 --- /dev/null +++ b/zig-x11/.clang-format @@ -0,0 +1,4 @@ +BasedOnStyle: LLVM +ColumnLimit: 120 +IndentWidth: 4 + diff --git a/zig-x11/Makefile b/zig-x11/Makefile new file mode 100644 index 0000000..910dd26 --- /dev/null +++ b/zig-x11/Makefile @@ -0,0 +1,8 @@ +default: + zig run main.zig -lX11 -lc + +window-test: + clang window.c -o window -lX11 + +window-test-zig: + zig cc window.c -o window -lX11 diff --git a/zig-x11/main.zig b/zig-x11/main.zig new file mode 100644 index 0000000..daa4cd5 --- /dev/null +++ b/zig-x11/main.zig @@ -0,0 +1,32 @@ +const std = @import("std"); +const xlib = @cImport({ + @cInclude("X11/Xlib.h"); +}); + +pub fn main() !void { + const display = xlib.XOpenDisplay(null); + if (display == null) { + return error.DisplayOpenFailed; + } + + const rootWindow = xlib.XDefaultRootWindow(display); + + const mainWindow = xlib.XCreateSimpleWindow( + display, + rootWindow, + 0, + 0, + 800, + 600, + 0, + 0, + 0xFF0000, + ); + + _ = xlib.XMapWindow(display, mainWindow); + _ = xlib.XFlush(display); + + while (true) { + std.time.sleep(1 * std.time.ns_per_s); + } +} diff --git a/zig-x11/window.c b/zig-x11/window.c new file mode 100644 index 0000000..80110c4 --- /dev/null +++ b/zig-x11/window.c @@ -0,0 +1,15 @@ +#include <X11/Xlib.h> +#include <unistd.h> + +int main() { + Display *MainDisplay = XOpenDisplay(0); + Window RootWindow = XDefaultRootWindow(MainDisplay); + + Window MainWindow = XCreateSimpleWindow(MainDisplay, RootWindow, 0, 0, 800, 600, 0, 0, 0xFF0000); + XMapWindow(MainDisplay, MainWindow); + XFlush(MainDisplay); + + for (;;) { + sleep(1); + } +} |
