Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/batiati/iupforzig
IUP (Portable User Interface Toolkit) bindings for the Zig language.
https://github.com/batiati/iupforzig
gui iup iup-gui-library iup-toolkit multiplatform zig zig-package ziglang
Last synced: 3 months ago
JSON representation
IUP (Portable User Interface Toolkit) bindings for the Zig language.
- Host: GitHub
- URL: https://github.com/batiati/iupforzig
- Owner: batiati
- License: unlicense
- Created: 2021-06-19T23:19:14.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-01-12T21:15:21.000Z (about 1 year ago)
- Last Synced: 2024-10-14T02:40:32.487Z (3 months ago)
- Topics: gui, iup, iup-gui-library, iup-toolkit, multiplatform, zig, zig-package, ziglang
- Language: Zig
- Homepage:
- Size: 3.55 MB
- Stars: 114
- Watchers: 5
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: ReadMe.md
Awesome Lists containing this project
README
# IUP for Zig
[![Lines of code](https://img.shields.io/tokei/lines/github/batiati/IUPforZig)]()
[![GitHub code size in bytes](https://img.shields.io/github/languages/code-size/batiati/IUPforZig)]()
[![made with Zig](https://img.shields.io/badge/made%20with%20%E2%9D%A4%20-Zig-orange)]()
[![made with Zig](https://img.shields.io/badge/unlicensed-public%20domain-brightgreen)]()A [Zig language](https://ziglang.org/) idiomatic and type-checked bindings for [IUP Portable User Interface Toolkit](https://tecgraf.puc-rio.br/iup/)
## Examples
- [Simple notepad (in progress)](docs/simple_notepad.md)
- [7GUIs](src/7gui/ReadMe.md)
- [Button](docs/button.md)
- [Image](docs/image.md)
- [List](docs/list.md)
- [Tree](docs/tree.md)
- [MDI](docs/mdi.md)
- [Gauge](docs/gauge.md)
- [Tabs](docs/tabs.md)![Simple Notepad Windows](docs/SimpleNotepadWindows.gif)
![Simple Notepad Ubuntu](docs/SimpleNotepadUbuntu.gif)
## First look
A simple hello world example looks like this:
```Zig
const iup = @import("iup.zig");pub fn main() !void {
try iup.MainLoop.open();
defer iup.MainLoop.close();var main_dialog = try (iup.Dialog.init()
.setTitle("Hello World")
.setChildren(
.{
iup.VBox.init()
.setMargin(10, 10)
.setGap(10)
.setAlignment(.ACenter)
.setChildren(
.{
iup.Label.init()
.setTitle("Hello World from IUPforZig"),
iup.Button.init()
.setTitle("OK")
.setActionCallback(exit),
},
),
},
).unwrap());
defer main_dialog.deinit();try main_dialog.showXY(.Center, .Center);
try iup.MainLoop.beginLoop();
}fn exit(button: *iup.Button) !void {
iup.MainLoop.exitLoop();
}
```Resulting in this:
![Hello World Windows](docs/HelloWorldWindows.jpg)
![Hello World Ubuntu](docs/HelloWorldUbuntu.jpg)
## IUP Metadata
This project contains source-code automatically generated by [The IUP Metadata Project](https://github.com/batiati/IUPMetadata).
Most of the hard/repetitive work was done by code-gen tool, however, the API guidelines and all the interop code belongs here on this project.
## API
Zig does not require any special treatment to use C libraries, so to use IUP in Zig, it is as simple as adding `@cInclude("iup.h") ` in your source code, no need for special bindings!
This project attempts to create Zig bindings for IUP Toolkit with idiomatic and type-checked API, where none of the original IUP's declarations are exposed in the public interface, only names and concepts are kept as close as possible.
## Comparison:
1. IUP [simple example](https://tecgraf.puc-rio.br/iup/examples/tutorial/example3_1.c) in C:
```C
#include
#includeint main(int argc, char **argv)
{
Ihandle *dlg, *multitext, *vbox;IupOpen(&argc, &argv);
multitext = IupText(NULL);
vbox = IupVbox(
multitext,
NULL);
IupSetAttribute(multitext, "MULTILINE", "YES");
IupSetAttribute(multitext, "EXPAND", "YES");dlg = IupDialog(vbox);
IupSetAttribute(dlg, "TITLE", "Simple Notepad");
IupSetAttribute(dlg, "SIZE", "QUARTERxQUARTER");IupShowXY(dlg, IUP_CENTER, IUP_CENTER);
IupSetAttribute(dlg, "USERSIZE", NULL);IupMainLoop();
IupClose();
return EXIT_SUCCESS;
}
```2. Equivalent example in Zig:
```zig
const iup = @import("iup.zig");pub fn main() !void {
try iup.MainLoop.open();
defer iup.MainLoop.close();var main_dialog = try (iup.Dialog.init()
.setTitle("Simple Notepad")
.setSize(.Quarter, .Quarter)
.setChildren(
.{
iup.VBox.init()
.setChildren(
.{
iup.Text.init()
.setMultiline(true)
.setExpand(.Yes),
},
),
},
).unwrap());
defer main_dialog.deinit();try main_dialog.showXY(.Center, .Center);
try iup.MainLoop.beginLoop();
}
```## How to build
1. Download [Zig](https://ziglang.org/download/);
2. Install IUP shared libraries and run:
> NOTE: [curl](https://curl.se/) is needed to download IUP binaries.
**Linux**
```bash
./install_iup.sh
zig build run
```**Windows**
```cmd
.\install_iup.bat
zig build run
```>For more information, please visit IUP's download page for your platform:
>https://sourceforge.net/projects/iup/files/3.30/>Dependencies for `libim` and `libcd` may be required:
>https://sourceforge.net/projects/imtoolkit/files/3.15/
>https://sourceforge.net/projects/canvasdraw/files/5.14/## Pending work
- [X] Support for collections and indexed attributes (list items for example)
- [ ] Complete the [Simple Notepad](https://github.com/batiati/IUPforZig/blob/master/src/example.zig) example.
- [X] Support Linux and Windows (using shared libs)
- [ ] Investigate how to build IUP from C sources in Zig.
- [ ] More tests, and sanitize failing tests.
- [ ] Additional controls (image library, matrix, GLCanvas, scintilla, plot, etc)
Feel free to place any comments/issues/PRs, it will be very nice to receive any feedback 🚀.
## Prior Art
Some great projects that served as inspiration.
- [Common Lisp CFFI bindings](https://github.com/lispnik/iup)
- [Iup4D is a D binding library](https://github.com/Heromyth/Iup4D)
- [IUP Rust](https://github.com/dcampbell24/iup-rust)
## License
* This project is a free and unencumbered software released into the public domain. Plese visit [unlicense.org](https://unlicense.org/) for more details.
* IUP is a [Tecgraf](http://www.tecgraf.puc-rio.br)/[PUC-Rio](http://www.puc-rio.br) project licensed under the terms of the [MIT license](http://www.opensource.org/licenses/mit-license.html). Please visit https://www.tecgraf.puc-rio.br/iup/ for more details.