Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samhocevar/portable-file-dialogs
💬 Portable GUI dialogs library, C++11, single-header
https://github.com/samhocevar/portable-file-dialogs
Last synced: 3 days ago
JSON representation
💬 Portable GUI dialogs library, C++11, single-header
- Host: GitHub
- URL: https://github.com/samhocevar/portable-file-dialogs
- Owner: samhocevar
- License: wtfpl
- Created: 2018-10-12T11:04:17.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-03-13T01:50:55.000Z (11 months ago)
- Last Synced: 2025-02-10T08:10:04.070Z (10 days ago)
- Language: C++
- Homepage:
- Size: 254 KB
- Stars: 1,054
- Watchers: 26
- Forks: 100
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
- awesome-game-engine-dev - Portable File Dialogs - Single-header C++11 native dialogs on Windows, macOS, and Linux. (Libraries / C++)
- awesome-audio-plugin-framework - Portable File Dialogs
- AwesomeCppGameDev - portable-file-dialogs - header (C++)
README
# Portable File Dialogs
A free C++11 file dialog library.
- works on Windows, Mac OS X, Linux
- **single-header**, no extra library dependencies
- **synchronous *or* asynchronous** (does not block the rest of your program!)
- **cancelable** (kill asynchronous dialogues without user interaction)
- **secure** (immune to shell-quote vulnerabilities)[data:image/s3,"s3://crabby-images/be89e/be89ee59f8983aba5927983fb1d8fd016d04148f" alt="Codacy Badge"](https://www.codacy.com/manual/samhocevar/portable-file-dialogs?utm_source=github.com&utm_medium=referral&utm_content=samhocevar/portable-file-dialogs&utm_campaign=Badge_Grade)
## Status
The library is now pretty robust. It is not as feature-complete as
[Tiny File Dialogs](https://sourceforge.net/projects/tinyfiledialogs/),
but has asynchonous dialogs, more maintainable code, and fewer potential
security issues.The currently available backends are:
- Win32 API (all known versions of Windows)
- Mac OS X (using AppleScript)
- GNOME desktop (using [Zenity](https://en.wikipedia.org/wiki/Zenity) or its clones Matedialog and Qarma)
- KDE desktop (using [KDialog](https://github.com/KDE/kdialog))Experimental support for Emscripten is on its way.
## Documentation
- [`pfd`](doc/pfd.md) general documentation
- [`pfd::message`](doc/message.md) message box
- [`pfd::notify`](doc/notify.md) notification
- [`pfd::open_file`](doc/open_file.md) file open
- [`pfd::save_file`](doc/save_file.md) file save
- [`pfd::select_folder`](doc/select_folder.md) folder selection## History
- 0.1.0 (July 16, 2020): first public release
## Screenshots (Windows 10)
data:image/s3,"s3://crabby-images/21da2/21da246120ae52dccbeb53f0c507baab81655983" alt="warning-win32"
data:image/s3,"s3://crabby-images/f4bea/f4beaeb80968eda812197d6dafb0d957df68b027" alt="notify-win32"
data:image/s3,"s3://crabby-images/e0071/e00712e77da3d4cdb15105794fb4abee72272d83" alt="open-win32"## Screenshots (Mac OS X, dark theme)
data:image/s3,"s3://crabby-images/1cf64/1cf641d489df9baced3a12422b39586e97184267" alt="warning-osxdark"
data:image/s3,"s3://crabby-images/d5ce6/d5ce6bcacd681fdb812d90c7673a061fe00cd984" alt="notify-osxdark"
data:image/s3,"s3://crabby-images/7e815/7e81509d602daea75ae378ab5aec9b0aa56a163b" alt="open-osxdark"## Screenshots (Linux, GNOME desktop)
data:image/s3,"s3://crabby-images/6d072/6d072c755f4ef0a814f68847a00b2e55469af0d6" alt="warning-gnome"
data:image/s3,"s3://crabby-images/db89a/db89a3ae77c9d1e6c26a765c062b55eff1649ef2" alt="notify-gnome"
data:image/s3,"s3://crabby-images/de848/de848514c21f3a38c427c3ec81ebe1a4ffcb1f57" alt="open-gnome"## Screenshots (Linux, KDE Plasma desktop)
data:image/s3,"s3://crabby-images/a8caa/a8caaae72803e52b3d743bd40947c9d9a6a97c9d" alt="warning-kde"
data:image/s3,"s3://crabby-images/f52f5/f52f5acdd45db2c3358881c267dae628f042927c" alt="notify-kde"
data:image/s3,"s3://crabby-images/7f801/7f8014240bc9dc4307d6f480459f6acec0228b0c" alt="open-kde"