Zenity dialogs for Golang, Windows, macOS
Go to file
2022-12-15 11:34:29 +00:00
.github Workflows. 2022-12-07 12:53:18 +00:00
cmd/zenity Fix panic. 2022-12-15 11:34:29 +00:00
internal Add IsAvailable. 2022-12-14 23:53:30 +00:00
scripts Username (macOS). 2022-05-11 18:19:13 +01:00
testdata Custom icons (test). 2022-05-09 15:50:25 +01:00
.gitignore WIP: zenity command (macos). 2020-01-07 00:57:50 +00:00
color_darwin.go Fix window icons (macOS). 2022-06-09 00:31:14 +01:00
color_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
color_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
color_windows.go Parent window id (windows). 2022-06-29 12:50:30 +01:00
color.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
date_darwin.go Use ptr. 2022-12-15 00:26:34 +00:00
date_test.go Refactor (windows). 2022-06-22 15:14:52 +01:00
date_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
date_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
date.go Use ptr. 2022-12-15 00:26:34 +00:00
entry_darwin.go Fix window icons (macOS). 2022-06-09 00:31:14 +01:00
entry_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
entry_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
entry_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
entry.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
file_darwin.go Fix window icons (macOS). 2022-06-09 00:31:14 +01:00
file_filter_test.go Case-fold patterns. 2022-12-15 03:05:44 +00:00
file_test.go Fix panic. 2022-12-15 11:34:29 +00:00
file_unix.go Case-fold patterns. 2022-12-15 03:14:04 +00:00
file_util_test.go Scripted user tests. 2021-07-08 17:15:12 +01:00
file_windows.go Fix panic. 2022-12-15 11:34:29 +00:00
file.go Case-fold patterns. 2022-12-15 03:05:44 +00:00
go.mod Bump golang.org/x/image from 0.1.0 to 0.2.0 2022-12-06 17:39:13 +00:00
go.sum Bump golang.org/x/image from 0.1.0 to 0.2.0 2022-12-06 17:39:13 +00:00
LICENSE Initial commit 2019-12-10 10:51:21 +00:00
list_darwin.go Errors, documentation. 2022-07-28 00:11:12 +01:00
list_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
list_unix.go Improve compatibility with zenity. 2022-11-22 23:10:47 +00:00
list_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
list.go Quote accelerators (&) on windows. 2022-12-07 14:55:24 +00:00
main_test.go WSL test improvements. 2021-07-29 16:20:50 +01:00
msg_darwin.go Fix window icons (macOS). 2022-06-09 00:31:14 +01:00
msg_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
msg_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
msg_windows.go Quote accelerators (&) on windows. 2022-12-07 14:55:24 +00:00
msg.go Documentation. 2022-12-05 01:32:15 +00:00
notify_darwin.go Refactor. 2021-03-04 12:42:30 +00:00
notify_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
notify_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
notify_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
notify.go Refactor. 2021-03-04 12:42:30 +00:00
progress_darwin.go Fixes focus issues, see #40. 2022-12-06 18:24:37 +00:00
progress_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
progress_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
progress_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
progress.go Improve compatibility with zenity. 2022-11-22 23:10:47 +00:00
pwd_darwin.go Fix window icons (macOS). 2022-06-09 00:31:14 +01:00
pwd_test.go Add window icons, tests. 2022-05-19 00:04:20 +01:00
pwd_unix.go Attach, modal (unix). 2022-06-02 11:24:24 +00:00
pwd_windows.go Use ptr. 2022-12-15 00:26:34 +00:00
pwd.go Errors, documentation. 2022-07-28 00:11:12 +01:00
README.md Update README.md 2022-07-10 22:55:39 +01:00
util_darwin.go Use ptr. 2022-12-15 00:26:34 +00:00
util_test.go Use ptr. 2022-12-15 00:26:34 +00:00
util_windows.go Icons (windows), see #35. 2022-07-27 00:25:18 +01:00
util.go Quote accelerators (&) on windows. 2022-12-07 14:55:24 +00:00
zenity_darwin.go Add IsAvailable. 2022-12-14 23:53:30 +00:00
zenity_test.go Fix panic. 2022-12-15 11:34:29 +00:00
zenity_unix.go Add IsAvailable. 2022-12-14 23:53:30 +00:00
zenity_windows.go Add IsAvailable. 2022-12-14 23:53:30 +00:00
zenity.go Use ptr. 2022-12-15 00:26:34 +00:00

Zenity dialogs for Golang, Windows and macOS

Go Reference Go Report Go Cover Mentioned in Awesome Go

This repo includes:

  • a cross-platform Go package providing Zenity-like dialogs (simple dialogs that interact graphically with the user)
  • a “port” of the zenity command to both Windows and macOS based on that library.

Implemented dialogs:

Behavior on Windows, macOS and other Unixes might differ slightly. Some of that is intended (reflecting platform differences), other bits are unfortunate limitations.

Installing

The Go package:

go get github.com/ncruces/zenity@latest

The zenity command on macOS/WSL using Homebrew 🍺:

brew install ncruces/tap/zenity

The zenity command on Windows using Scoop 🍨:

scoop install https://ncruces.github.io/scoop/zenity.json

The zenity command on macOS/Windows, if you have Go:

go install github.com/ncruces/zenity/cmd/zenity@latest

Or download the latest release.

Using

For the Go package, consult the documentation and examples.

The zenity command does its best to be compatible with the GNOME version.
Consult the documentation and man page of that command.

Why?

Benefits of the Go package:

  • no cgo (see benefits, mostly cross-compilation)
  • no main loop (or any other threading or initialization requirements)
  • cancelation through context
  • on Windows:
    • no additional dependencies
      • Explorer shell not required
      • works in Server Core
    • Unicode support
    • High DPI (no manifest required)
    • Visual Styles (no manifest required)
    • WSL/Cygwin/MSYS2 support
  • on macOS:
    • only dependency is osascript
  • on other Unixes:
    • wraps either one of zenity, qarma, matedialog

Credits

I'd like to thank all contributors, but @gen2brain in particular for dlgs, which was instrumental to the Windows port of zenity.