Compare commits

...

154 Commits
0.5 ... dev

Author SHA1 Message Date
zenobit 8b499b744f moved while true; do 2023-12-14 04:55:00 +01:00
zenobit 6e7fa260b6 added quicktui 2023-12-14 04:55:00 +01:00
zenobit 5b42eebffe wrong function name 2023-12-14 04:55:00 +01:00
zenobit c3bd9eb195 merge upstream and other changes
added sparky linux
added bazzite
2023-11-17 14:35:57 +01:00
zenobit 52182514ec
Delete CNAME 2023-10-05 11:03:18 +02:00
zenobit e9ce6d4f58 portable mode: ./ instead of pwd for paths
Portable mode: not full path in desktop files
2023-10-05 02:35:12 +02:00
zenobit f67d896b23 prepare icons for whonix and guix 2023-10-05 02:07:13 +02:00
zenobit 971938f1e6 Add Trisquel GNU Linux 2023-10-05 02:07:13 +02:00
zenobit c9adf8c8fa
bug: dh not work under wayland properly 2023-10-04 21:48:40 +02:00
zenobit 3187b15c33
Update README.md 2023-10-04 05:12:00 +02:00
zenobit 08c7a93276
New SimpleX chat group link 2023-10-04 04:09:00 +02:00
zenobit 49beacbf4c renew_ready: Use old function 2023-10-04 03:14:42 +02:00
zenobit 901a25bda8 update currently supported operating systems 2023-10-04 02:52:58 +02:00
zenobit 927c062ce8 raise version to 0.80 2023-10-03 21:54:53 +02:00
zenobit a574a3e737 up 2023-10-03 21:45:06 +02:00
zenobit 67686fcada quickemu fix nproc
Better handling available cores
2023-10-02 00:03:29 +02:00
zenobit ca8023bc27 update quickget
repair BSDs bug `grep: warning: stray \ before "`
2023-10-01 20:31:44 +02:00
zenobit 985cf25b7d make quickfzf executable 2023-09-15 00:48:45 +02:00
zenobit 331cccaa34 Update README.md 2023-09-15 00:45:03 +02:00
zenobit 302d4df44b Create quickfzf 2023-09-15 00:45:03 +02:00
zenobit 5c5048aa26 Update quickget 2023-09-15 00:45:03 +02:00
zenobit 8a6a151b50 Add Miyo.png 2023-09-15 00:45:03 +02:00
zenobit f3bfd314f4
Update quickget 2023-09-02 03:25:36 +02:00
zenobit 62a51945e0 🆕 feat(lang): add new language files
Added new language files to the project. These files contain a list of messages used in the application. The messages are used to display information to the user, such as status updates, error messages, and prompts. The files are named `promenne1.txt`, `promenne2.txt`, `raw_comments.cfg`, `raw_echo.cfg`, and `raw_msg.cfg`.

🆕 feat(lang): add new language files
Added new language files to support localization of the application. The new files include `raw_printf.cfg`, `strings.cfg`, `strings0.cfg`, `strings1.cfg`, and `strings2.cfg`. These files contain translations for various messages and prompts used in the application. The addition of these files will allow users to use the application in their preferred language.

🗑️ chore(translate.sh): remove translate.sh script
The translate.sh script has been removed from the repository as it is no longer needed. The script was used to automatically translate base language strings and add them into the various translations, remove duplicate strings, and rearrange them alphabetically. However, the script is no longer being used and has been removed.
2023-04-14 10:53:39 +02:00
zenobit 545577b497 new RAW translations 2023-04-14 07:58:46 +02:00
zenobit 3ac2db2487 🔥 chore(desktop): remove alpine-3.12 and netboot-latest desktop entries
The desktop entries for alpine-3.12 and netboot-latest have been removed. These entries are no longer needed and have been deleted to reduce clutter.
2023-04-12 20:50:42 +02:00
zenobit cce6c90af2 🔀 chore(cs.cfg): reorganize and clean up language configuration file
The changes in this commit include reorganizing the language configuration file to improve readability and removing unused or unnecessary messages. Some messages were also renamed to better reflect their purpose. The commit also includes minor changes such as fixing typos and removing unnecessary whitespace.

🌐 chore(lang): update language files
The commit updates the language files for the DistroHopper application. The changes include adding new translations, updating existing translations, and fixing typos. The commit also removes some unused translations.

🌐 feat(lang): add Spanish and French translations
This commit adds Spanish and French translations to the project. The new files are located in the lang directory and contain translations for various messages and prompts used throughout the application. The addition of these translations will allow users who speak Spanish or French to use the application in their native language.
2023-04-12 20:49:29 +02:00
zenobit 93270cdb97 WIP 2023-04-12 20:45:14 +02:00
zenobit d279d23447 desktop files test 2023-04-12 20:44:40 +02:00
zenobit a3c32152a8 🐛 fix(dh): fix typo in message variable name
 feat(dh): improve user messages
The commit fixes a typo in the message variable name. The commit also improves user messages by making them more descriptive and user-friendly. The messages now provide more context and instructions to the user, making it easier for them to understand what is happening and what actions they need to take.
2023-04-12 16:42:34 +02:00
zenobit 3ca9da5bc1 🐛 fix(dh): change variable name from TERMINAL to terminal
The variable TERMINAL has been renamed to terminal to improve consistency with the naming conventions. The change has been made in multiple places in the code.
2023-04-12 13:46:44 +02:00
zenobit 798ce0f291 🔥 chore(dh): remove unused WIP2 function
The WIP2 function is not used in the script and can be safely removed.
2023-04-12 02:01:30 +02:00
zenobit 7fb5c35af1 🐛 fix(dh): refactor dependencies_install function
 feat(dh): add support for multiple package managers
The dependencies_install function has been refactored to use separate functions for each package manager. This makes it easier to add support for new package managers in the future. Support for apt, pacman, xbps, and dnf has been added. This improves the flexibility of the script as it can now be used on a wider range of systems.
2023-04-12 01:18:19 +02:00
zenobit 16b193dee3 🐛 fix(dh): set correct icon path for hop icon
The icon path for the hop icon was not set correctly in some parts of the code. The variable $icon_file was not defined, so the icon path was not being set correctly. The correct path is now set to $DH_ICON_DIR/hop.svg.
2023-04-12 01:17:19 +02:00
zenobit 1717296740 🐛 fix(dh): rename locale directory to lang
The locale directory was renamed to lang to better reflect its contents.
2023-04-11 22:11:43 +02:00
zenobit aee9c57078 🎨 style(README.md): add Gitmoji badge to README.md and docs/README.md
The Gitmoji badge was added to the README.md and docs/README.md files to improve the visual appeal of the repository and to indicate the use of Gitmoji in commit messages.
2023-04-09 15:32:03 +02:00
zenobit 7ccdb41780 docs: add opencommit to the list of tools for editing in README.md and docs/README.md 2023-04-09 13:43:20 +02:00
zenobit 2fb02ce52b style(dh): fix formatting and indentation in dh script
feat(dh): add TOOL_set_default_terminal function to set default terminal emulator
refactor(dh): rename TOOL_distrohopper_translate to TOOL_dh_translate
2023-04-09 13:38:38 +02:00
zenobit 62025303aa refactor(dh): remove duplicate package installations and fix typo in package name
feat(dh): add support for openSUSE package manager dnf and remove unused common_dependencies variable
2023-04-09 01:14:33 +00:00
zenobit 6c68906e69 feat(quickget): add support for gabeeOS qtile and budgie editions 2023-04-09 01:11:36 +00:00
zenobit 714f96bbde
Merge pull request #17 from grm34/auto-translate 2023-04-02 23:17:48 +02:00
grm34 ecb4cb7be0 LANG: sorts VARS alpha (auto-translate)
Signed-off-by: grm34 <jerem.pardo@tutanota.com>
2023-04-02 21:42:23 +02:00
grm34 82cdbf001b LANG: adds an automatic translation script (deepl)
Signed-off-by: grm34 <jerem.pardo@tutanota.com>
2023-04-02 21:38:18 +02:00
zenobit 7f9a85e1f7 refactor(dh): replace hardcoded strings with variables and improve readability
refactor(dh): replace hardcoded strings with variables in the dh script

refactor(lang): improve language translations and remove unnecessary escape characters

chore(lang): update language files formatting and translations
2023-04-02 11:14:03 +02:00
zenobit 7cdb647f6f feat(dh): add language support for distrohopper
fix(dh): comment out unused export statements
fix(dh): fix typo in message string
fix(dh): fix typo in language directory name
fix(dh): fix typo in copying translation to system directory
refactor(dh): remove unused function WIP2
refactor(dh): rename function WIP to distrohopper_gui
refactor(dh): rename variable lang to LANGUAGE
refactor(dh): rename variable DH_CONFIG_DIR to DH_CONFIG_DIR_PATH
refactor(dh): rename variable DH_ICON_DIR to DH_ICON_DIR_PATH
refactor(dh): rename variable VMS_DIR to VM_DIR_PATH
refactor(dh): rename variable TERMINAL to DEFAULT_TERMINAL
refactor(dh): rename variable replace to REPLACE_CHAR
refactor(dh): rename variable portable_prefix to PORTABLE_PREFIX
refactor(dh): rename variable TMP_DIR to TEMP_DIR_PATH
2023-04-02 05:50:25 +02:00
zenobit 8c456de2d6 deleted old translation 2023-04-02 05:35:24 +02:00
zenobit 66d3b7cd8c better translation 2023-04-02 05:34:04 +02:00
zenobit 550efbdd2a Make dragonflybsd release dynamic 2023-04-02 00:52:45 +02:00
zenobit 31d12308dd Make NetBSD releases dynamic 2023-04-02 00:52:45 +02:00
zenobit ed91e62042 macOS Ventura support 2023-04-02 00:52:45 +02:00
zenobit a9bfb2dbf6 Add custom size for NixOS 2023-04-02 00:52:45 +02:00
zenobit 74e492fe7c Prepare for 23.04 and add Ubuntu Cinnamon 2023-04-02 00:52:45 +02:00
zenobit 5a78cbdb86 testing! NOT FOR MERGE!!! 2023-03-31 14:29:05 +02:00
zenobit f73ace45a5 renaming again 2023-03-31 08:19:04 +02:00
zenobit 94e364a35e WIP 2023-03-31 08:17:35 +02:00
zenobit b4da972f04 create script nicer to look for me 2023-03-31 08:17:02 +02:00
zenobit 8ac01b4d21 windows renaming 2023-03-31 05:52:59 +02:00
zenobit 8f3adab524 renaming continue 2023-03-31 05:18:02 +02:00
zenobit 3a23b6db14 functions renaming 2023-03-31 04:46:02 +02:00
zenobit 68e148b5fc Big loop refactoring 2023-03-31 01:37:15 +02:00
zenobit 95c3e6c228 Kill dh set -e 2023-03-31 01:36:40 +02:00
zenobit 7be96b8301 cereus no base edition 2023-03-30 15:58:43 +02:00
zenobit 330784b46d renew_ready fix 2023-03-30 13:13:23 +02:00
zenobit 534722e0f4 web update 2023-03-30 13:12:25 +02:00
zenobit 4cea186907 yad bigger windows 2023-03-30 10:05:32 +02:00
zenobit 6ee973100e function desktop_entry 2023-03-30 10:04:58 +02:00
zenobit 82a5c17ad3 strings change 2023-03-30 10:04:15 +02:00
zenobit cbdd5cc25d TMP_DIR 2023-03-30 10:04:15 +02:00
zenobit a057e0ec39 testing function 2023-03-30 10:04:15 +02:00
zenobit bed6ef56ff run in terminal option 2023-03-30 09:09:59 +02:00
zenobit 028ae25446 shellcheck source 2023-03-30 09:07:15 +02:00
zenobit d8d5223999 desktop entry 2023-03-30 05:39:38 +02:00
zenobit cb7b17ca0d
Update README.md 2023-03-30 05:10:42 +02:00
zenobit bfae5ccfa7 No cereus base image yet 2023-03-30 04:47:55 +02:00
zenobit a5f25aeb62 ready use EOF and small fix 2023-03-30 04:46:02 +02:00
zenobit e94ee28b81 language changes 2023-03-30 04:46:02 +02:00
zenobit 6d6f21896e prefix names changed 2023-03-30 04:45:52 +02:00
zenobit 3289728d9e desktop files fix 2023-03-30 04:45:52 +02:00
zenobit 76f3e44cc4 make copying translation optional 2023-03-30 01:16:56 +02:00
zenobit 94f6908076 env bash 2023-03-30 01:16:06 +02:00
zenobit a28759b0c5 version 0.77b 2023-03-30 00:00:01 +02:00
zenobit 09d1f4534d lines with tabs: printf and \t instead of echo 2023-03-29 23:33:30 +02:00
zenobit afbde282cc missed string for translation 2023-03-29 23:10:23 +02:00
zenobit 54efce9613 cleanup 2023-03-29 23:05:25 +02:00
zenobit a714df5598 czech translation 2023-03-29 23:05:25 +02:00
zenobit 091c2511c6 include supported .desktop files 2023-03-29 22:31:22 +02:00
zenobit fc9457da2b reworked renew_supported 2023-03-29 22:31:22 +02:00
zenobit a39cc83b6e improved messages 2023-03-29 22:31:22 +02:00
zenobit 22387b1355 essential fix 2023-03-29 22:31:22 +02:00
zenobit 525269512c suppress output if creating or removing files/directories fail 2023-03-29 22:31:22 +02:00
zenobit 524e226fb8 no dashes in arguments 2023-03-29 22:31:22 +02:00
zenobit 801911ce2f README 2023-03-29 22:31:22 +02:00
zenobit d33704f44d raise to 0.76 2023-03-29 22:31:22 +02:00
zenobit ee4739dcc5 pacman apt xbps dnf support 2023-03-28 02:31:08 +02:00
zenobit cb514e6566 updated README and translation 2023-03-28 01:38:28 +02:00
zenobit 62faa8fcb8 updated README 2023-03-28 01:09:02 +02:00
zenobit a42b38e19f localisation 2023-03-28 00:13:02 +02:00
zenobit c8ec6743b6 delete old 2023-03-27 06:22:45 +02:00
zenobit 179c616af3 add quickemu origin as submodule 2023-03-27 06:21:37 +02:00
zenobit 4b88622621 change gettext header 2023-03-27 04:49:47 +02:00
zenobit 8940884423 export TEXTDOMAIN and TEXTDOMAINDIR 2023-03-27 04:39:27 +02:00
zenobit edfa1e3753 empty strings_dump for translation 2023-03-27 04:37:30 +02:00
zenobit c94908399d include supported 2023-03-27 04:29:57 +02:00
zenobit 80afdf28aa gettext repair 2023-03-27 02:41:08 +02:00
zenobit a47294ed7a function create_translation_source 2023-03-27 02:40:53 +02:00
zenobit fc73efe0ca add function sort_functions 2023-03-27 02:38:27 +02:00
zenobit 7882e1a003 locales 2023-03-27 02:37:04 +02:00
zenobit f2a662ad14 small fix 2023-03-26 22:27:45 +02:00
zenobit 4c43070019 en.po (template) 2023-03-26 22:24:51 +02:00
zenobit 6d9992bc6c cs 2023-03-26 22:24:35 +02:00
zenobit 4b716aaa93 (could have bugs and break anytime) 2023-03-26 21:36:28 +02:00
zenobit acabd52677 add gettext to installation (Void Linux) 2023-03-26 21:34:50 +02:00
zenobit 14fbe3e561 display versions in help 2023-03-26 21:34:22 +02:00
zenobit a6e5d0a6e1 rename functions to functions ... 2023-03-26 21:33:52 +02:00
zenobit d4a4fd1849 Add gettext support 2023-03-26 21:33:52 +02:00
zenobit df0cbe0875 add cs.po 2023-03-26 21:28:05 +02:00
zenobit 3a7cc73b8f test: supported edition (ubuntu) 2023-03-26 17:19:40 +02:00
zenobit cecab60053 0.7 raise version 2023-03-26 17:10:05 +02:00
zenobit ab299c39e8 arguments improved 2023-03-26 17:09:39 +02:00
zenobit bc29310628 some_bugs: improved info 2023-03-26 16:57:53 +02:00
zenobit b21df59a67 prepare debian and fedora installation 2023-03-26 03:11:08 +02:00
zenobit fdca51a41a SimpleX link 2023-03-24 12:47:55 +01:00
zenobit 94a6605ff9 screenshot 2023-03-24 12:47:55 +01:00
zenobit 2de80c8861 video: new version out! 2023-03-24 07:36:23 +01:00
zenobit 4e18988ce4 fix: structure issues 2023-03-24 06:57:02 +01:00
zenobit 48ba3e48e7 fix: renew_supported 2023-03-24 06:25:33 +01:00
zenobit 4c1b91d7ca remove old files 2023-03-24 06:24:50 +01:00
zenobit da21e4daf8 run portable or not 2023-03-24 05:44:51 +01:00
zenobit 57261c2f53 moving 2023-03-24 02:54:49 +01:00
zenobit cdf14d114c meld fix 2023-03-24 00:10:24 +01:00
zenobit fa40b3ed25 added emty dirs 2023-03-23 23:58:49 +01:00
zenobit ff5155730c dh next 2023-03-23 23:41:29 +01:00
zenobit 00d0165368 prepare release 2023-03-23 21:21:46 +01:00
zenobit 69abdb7a08 donate 2023-03-23 06:33:02 +01:00
zenobit af61674313 README and subtitle 2023-03-23 03:34:25 +01:00
zenobit 6d9637de9f dh: temporary duplicate 2023-03-23 00:44:21 +01:00
zenobit 1168b32dd0 SimpleX logo in README 2023-03-23 00:42:55 +01:00
zenobit 68a08e79e6 move documents 2023-03-22 23:30:32 +01:00
zenobit 8cd0fe4883 own domain 2023-03-22 23:30:32 +01:00
zenobit bcd629a00a merge all to dh 2023-03-22 09:23:04 +01:00
zenobit 7c3a942aea no version in window title 2023-03-22 09:23:04 +01:00
zenobit e98c2f535f Update README.md 2023-03-22 09:23:04 +01:00
zenobit 0f98954659 used: geany meld 2023-03-22 09:23:04 +01:00
zenobit c94dbaad8e artwork 2023-03-22 09:23:04 +01:00
zenobit 295424611e discussion 2023-03-22 09:23:04 +01:00
zenobit 3c63a8bbe1 badges 2023-03-22 09:23:04 +01:00
root e7768847f6 vxlinux: 7.0 2023-03-22 09:23:04 +01:00
zenobit 8da4d7a717 mirrors 2023-03-22 09:23:04 +01:00
zenobit 02f69b3fda move icons 2023-03-22 09:22:44 +01:00
zenobit 07d8224d13 mirrors 2023-03-21 18:47:05 +01:00
zenobit 6656f379f2 prepare release 0.5 2023-03-21 17:11:21 +01:00
zenobit 7a4232af63 GTK_THEME 2023-03-21 17:05:40 +01:00
zenobit 7e9fcae435 move icons 2023-03-21 17:05:40 +01:00
zenobit 049bd1a6f8 rename variables to: DH_CONFIG_DIR DH_CONFIG DH_ICON_DIR 2023-03-21 17:00:14 +01:00
346 changed files with 953853 additions and 2350 deletions

3
.gitmodules vendored Normal file
View File

@ -0,0 +1,3 @@
[submodule "quickemu-origin"]
path = quickemu-origin
url = https://github.com/quickemu-project/quickemu

1
README-web.md Symbolic link
View File

@ -0,0 +1 @@
docs/README.md

359
README.md
View File

@ -1,40 +1,81 @@
Want you try new Operating system?
![](https://img.shields.io/github/stars/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=instatus&logoColor=000000)
![](https://img.shields.io/github/forks/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=git&logoColor=000000)
![](https://img.shields.io/github/license/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=apache&logoColor=000000)
![](https://img.shields.io/github/repo-size/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=files&logoColor=000000)
![](https://img.shields.io/github/last-commit/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=codeigniter&logoColor=000000)
![](https://img.shields.io/badge/language-shell-green?style=for-the-badge&color=8BC53F&logo=sharp&logoColor=000000)
![](https://img.shields.io/badge/gitmoji-%20😜%20😍-FFDD67.svg?style=for-the-badge&color=8BC53F&logo=sharp&logoColor=000000&alt="Gitmoji")
---
# Looking to try out a new operating system?
try
[DistroHopper](https://github.com/oSoWoSo/DistroHopper)
# **DistroHopper**
Quickly download, create and run VM of any#TODO operating system.
![Hop](config/icons/hop.svg)
Quickly download, create and run VM of any(TODO) operating system.
# For now yad not work under wayland correctly
Until this will be solved upstream use just quickfzf TUI under wayland!
It's even quicker and easier to use.
But don't have that nice distro icons you never heard about.. (or no?)
Linux![Tux](docs/tux23.png) required...
---
Click on Hop for latest download
[![Hop](docs/hop120.png)](https://sourceforge.net/projects/distrohopper/files/latest/download)
[![Donate](https://liberapay.com/assets/widgets/donate.svg)](https://liberapay.com/zenobit/donate)
Licensed under AGPL3
### Still Testing version!
![dh](distrohopper.png)
# Still Beta version!
<details>
<summary>Click for screenshot</summary>
<img src="docs/distrohopper.png">
</details>
As a base excellent [quickemu](https://github.com/quickemu-project/quickemu) (Link to project page)
[![quickemu video: Replace VirtualBox with Bash &
QEMU](https://img.youtube.com/vi/AOTYWEgw0hI/0.jpg)](https://www.youtube.com/watch?v=AOTYWEgw0hI)
quickly create and run VMs
You can download new distro with **few clicks** of a mouse
As a base excellent [quickemu](https://github.com/quickemu-project/quickemu)
you can download new distro with few clicks of a mouse
## GUI using yad
# Features
- GUI using yad (on youtube)
See it in action on youtube...
[![dh](https://img.youtube.com/vi/RrFQECcwLRA/0.jpg)](https://www.youtube.com/watch?v=RrFQECcwLRA)
[![dh](https://img.youtube.com/vi/JtjIseqZMkQ/0.jpg)](https://www.youtube.com/watch?v=JtjIseqZMkQ)
or command line?...
## TUI using fzf
- TUI using fzf (on youtube)
[![tui](https://img.youtube.com/vi/gJ5hqYEskOw/0.jpg)](https://www.youtube.com/watch?v=gJ5hqYEskOw)
- Desktop(shortcuts) entries generator
## .Desktop file generator
It will simple generate .desktop files for every supported and downloaded VM in quickemu.
So you can link it anywhere...
- Set dir where VMs will be stored
- Install DistroHopper systemwide
- Portable mode (dependecies still must be installed)
- Add new operating system to quickget (bit easier)
- Copy all downloaded ISOs to destination directory
- Translate DistroHopper (Currently supported English and Czech language)
Developed in English and translated into Czech language.
## Welcome translations!
---
# Why am I doing it?
Because I wanna learn
@ -53,21 +94,14 @@ And contribute to open source
And easily add new distros to it
---
# How to run DistroHopper?
## How to run DistroHopper?
You need fullfill the requirement first...
Quickemu.
[![quickemu video: Replace VirtualBox with Bash &
QEMU](https://img.youtube.com/vi/AOTYWEgw0hI/0.jpg)](https://www.youtube.com/watch?v=AOTYWEgw0hI)
## Requirements (For running VMs)
- [QEMU](https://www.qemu.org/) (*6.0.0 or newer*) **with GTK, SDL,
SPICE & VirtFS support**
- [QEMU](https://www.qemu.org/) (*6.0.0 or newer*) **with GTK, SDL, SPICE & VirtFS support**
- [bash](https://www.gnu.org/software/bash/) (*4.0 or newer*)
- [Coreutils](https://www.gnu.org/software/coreutils/)
- [EDK II](https://github.com/tianocore/edk2)
@ -100,114 +134,245 @@ packaging will take care of the dependencies. For other host
distributions or operating systems it will be necessary to install the
above requirements or their equivalents.
These examples may save a little typing
If you install DistroHopper, it should take care of dependencies on Arch, Debian, Ubuntu, openSuse and Fedora
Debian:
### For DistroHopper to work you need
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip
`wget yad fzf`
Fedora:
quickemu is included
sudo dnf install qemu bash coreutils edk2-tools grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-gtk-tools swtpm wget xdg-user-dirs xrandr unzip
Void Linux:
sudo xbps-install qemu bash coreutils grep jq procps-ng python3 util-linux sed spice-gtk swtpm usbutils wget xdg-user-dirs xrandr unzip zsync socat
# For Distrohopper to work you need `wget yad fzf` quickemu is included
For adding new distros, or adding/improving translations you will need also meld.
# How to install DistroHopper?
You need get copy of distrohopper
If you want more stable, download latest [release](https://github.com/oSoWoSo/DistroHopper/releases) version
If you want developer version... (could have bugs)
`git clone https://github.com/oSoWoSo/DistroHopper`
Enter created/unpacked distrohopper directory
Then enter config directory
`cd distrohopper/config`
And run
`./1stRun.sh`
Now should be good to go...
# How to run
If you want more stable experience, download latest release from
#### [GitHub](https://github.com/oSoWoSo/DistroHopper/releases) or SourceForge [![SourceForge](https://img.shields.io/sourceforge/dt/distrohopper.svg)](https://sourceforge.net/projects/distrohopper/files/latest/download)
---
If you want latest developer version... (could have bugs and break anytime)
Or you want translate DistroHopper
`git clone https://github.com/oSoWoSo/DistroHopper`
Enter created/unpacked distrohopper directory
Now you should be good to go...
---
# How to run DistroHopper
Just run from terminal
`dh`
or for TUI version (Download and run from/into same directory)
`dh -t`
# Desktop files
All desktop files will be storred in your .config
in directories /distrohopper/ready and supported
Fell free to link them anywhere you want...
`./dh`
# Currently supported Distribution:
And you will see what next...
In screenshot above...
I am usually run DistroHopper as:
### Testing version!
`./dh m r s l && ./dh i && dh g`
# Project chat group:
If anyone wanna join, here is one
[SimpleX](https://simplex.chat/contact#/?v=1-2&smp=smp%3A%2F%2FSkIkI6EPd2D63F4xFKfHk7I1UGZVNn6k1QWZ5rcyr6w%3D%40smp9.simplex.im%2FzmtsZwfTjwyynibt0bF6bb_xLWS9ce5A%23%2F%3Fv%3D1-2%26dh%3DMCowBQYDK2VuAyEAkMtz66wGfWb6VDn-_t_mVm3RFiFfOC3Hxye8Hm5tmVo%253D%26srv%3Djssqzccmrcws6bhmn77vgmhfjmhwlyr3u7puw4erkyoosywgl67slqqd.onion&data=%7B%22type%22%3A%22group%22%2C%22groupLinkId%22%3A%22o8KR0TOM0f2j33nO9goMRQ%3D%3D%22%7D) way
(But...)
## Desktop files
All desktop files will be storred in your .config/distrohopper
in directories *ready* and *supported*
Fell free to copy them anywhere you want...
### Currently supported Operating Systems and tools:
agarimos
alma
alpine
android
arch
archcraft
arco
artix
athenaos
batocera
biglinux
blendos
bodhi
cachyos
centos-stream
cereus
chimera
debian
deepin
devuan
dietpi
dragonflybsd
edubuntu
elementary
endeavouros
endless
fedora
freebsd
freedos
fvoid
gabeeos
garuda
gentoo
ghostbsd
haiku
holoiso
kali
kdeneon
kolibrios
kubuntu
lite
lmde
mageia
manjaro
mint
miyo
mx
netboot
netbsd
nixos
lubuntu
macos
openbsd
openindiana
opensuse
oracle
popos
reactos
rebornos
rocky
siduction
slackware
slax
slitaz
solus
tails
tinycore
truenas-core
truenas-scale
tuxedoos
ubuntu
ubuntu-budgie
ubuntucinnamon
ubuntukylin
ubuntu-mate
ubuntu-server
ubuntustudio
ubuntu-unity
vanillaos
ventoy
void
voidpup
vx
windows
xero
xubuntu
zorin
Also with posible planned: [in discusion](https://github.com/oSoWoSo/DistroHopper/discussions/9)
---
#### [discuss](https://github.com/oSoWoSo/DistroHopper/discussions) on github
# Join DistroHopper chat group:
[![SimpleX](docs/simplex.svg)](https://simplex.chat/contact#/?v=1-4&smp=smp%3A%2F%2Fu2dS9sG8nMNURyZwqASV4yROM28Er0luVTx5X1CsMrU%3D%40smp4.simplex.im%2FnTkG5MBnhRsRTb4heK-8J9jo0Vqc43q2%23%2F%3Fv%3D1-2%26dh%3DMCowBQYDK2VuAyEA-Go_Cwwzp419dls_-cmYvePuTyKdZ6bsrXAy8K1Sizc%253D%26srv%3Do5vmywmrnaxalvz6wi3zicyftgio6psuvyniis6gco6bp6ekl4cqj4id.onion&data=%7B%22type%22%3A%22group%22%2C%22groupLinkId%22%3A%228L5-Gq789MCV_wUQuNtTLg%3D%3D%22%7D) (click SimpleX logo)
(check the software! even if you don't want chat about DistroHopper)
[Simplex website](https://simplex.chat)
# Without these amazing projects it wouldn't be posible:
[bash](https://www.gnu.org/software/bash/)
#### [bash](https://www.gnu.org/software/bash/)
[QEMU](https://www.qemu.org/)
#### [QEMU](https://www.qemu.org/)
[quickemu](https://github.com/quickemu-project/quickemu)
#### [quickemu](https://github.com/quickemu-project/quickemu)
GUI depends on
[yad](https://github.com/v1cont/yad)
#### [yad](https://github.com/v1cont/yad)
TUI depends on
[fzf](https://github.com/junegunn/fzf)
#### [fzf](https://github.com/junegunn/fzf)
----
For easy of use
For
[fish](https://fishshell.com)
- easy of use
For commiting and working with github
#### [fish](https://fishshell.com)
[lazygit](https://github.com/jesseduffield/lazygit)
- commiting and working with github
Editing done mostly in
#### [lazygit](https://github.com/jesseduffield/lazygit)
[Kate](https://apps.kde.org/kate)
#### [opencommit](https://github.com/di-sukharev/opencommit)
Logo and icons edited in
- Editing
[GIMP](https://www.gimp.org)
#### [geany](https://geany.org/)
#### [Kate](https://apps.kde.org/kate)
- diff
#### [Meld](https://meld.app/)
- Logo and icons
#### [GIMP](https://www.gimp.org)
and
[Inkscape](https://inkscape.org)
#### [Inkscape](https://inkscape.org)
[logo by](https://freesvg.org/by/OpenClipart) bit repaired by me..
#### [logo by](https://freesvg.org/by/OpenClipart) bit repaired by me..
- Updating translation
#### [Poedit](https://poeditor.com/)
Everything done on
[Void Linux](https://voidlinux.org)
#### [Void Linux](https://voidlinux.org)
---
# Mirrored on
#### [GitHub](https://github.com/oSoWoSo/DistroHopper)
#### [SourceForge](https://sourceforge.net/projects/distrohopper)
#### [Disroot](https://git.disroot.org/oSoWoSo/DistroHopper)
#### [Codeberg](https://codeberg.org/oSoWoSo/DistroHopper)
#### [GitLab](https://gitlab.com/osowoso/distrohopper)
#### [SourceHut](https://git.sr.ht/~osowoso/DistroHopper)
---
For Homepage click on Hop
[![Hop](docs/hop120.png)](https://dh.osowoso.xyz/)
# donate
[![Donate](https://liberapay.com/assets/widgets/donate.svg)](https://liberapay.com/zenobit/donate)
@zen0bit at github
mailto: <zenobit@osowoso.xyz>
#### parent site [oSoWoSo](https://osowoso.xyz)

View File

@ -1,44 +0,0 @@
#!/bin/bash
yad --form --field="Name" "" --field="Releases" "" --field="Editions" "" --field="URL" "" --field="ISO" ""
# little script for adding distros to quickemu
# This version use desktop files and notebook
#TODO ADD_PRETTY_NAME_${DISTRO}
${DISTRO}) PRETTY_NAME="VX Linux";;
#TODO ADD_NAME_${DISTRO}
${DISTRO} \
#TODO ADD_releases_${DISTRO} function
function releases_${DISTRO}() {
echo 6.1 5.0 4.2 4.1 4.0
}
#TODO ADD_editions_${DISTRO} function
function editions_${DISTRO}() {
echo
}
#TODO ADD_get_${DISTRO} function
function get_${DISTRO}() {
local HASH=""
local ISO=""
local URL="https://github.com/dessington/${DISTRO}/releases/download/${RELEASE}"
if [ "$RELEASE" == "4.0" ]; then
ISO="vx-linux-4.0-qt.iso"
else
ISO="vx-linux-${RELEASE}.iso"
fi
echo "${URL}/${ISO} ${HASH}"
}
function get_voidpup() {
local HASH=""
local URL=""
local TMPURL=""
TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/vpup/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4)
URL=${TMPURL%\?*}
echo "${URL} ${HASH}"
}

92
auto-translate Executable file
View File

@ -0,0 +1,92 @@
#!/usr/bin/env bash
#
# Copyright (c) 2023 darkmaster @grm34
#
# This script automatically translates base language strings and adds
# them into the various translations (original will be used on error).
# It also removes duplicate strings and rearranges them alphabetically.
_sort_strings() {
# RM duplicate strings from an array and sorts them alphabetically.
# Usage: _sort_strings "$@" (array of strings)
# Returns: $sorted_strings (array)
local string strings
declare -A strings
for string in "${@}"; do
[[ $string ]] && IFS=" " strings["${string:- }"]=1
done
# shellcheck disable=SC2207
IFS=$'\n' sorted_strings=($(sort <<< "${!strings[*]}"))
}
_clean_cfg_files() {
# RM duplicates lines and sorts them alphabetically.
# Usage: _clean_cfg_files "$@" (array of files)
local file
for file in "$@"; do
mapfile -t strings < "$file"
_sort_strings "${strings[@]}"
printf "%s\n" "${sorted_strings[@]}" > "$file"
done
}
_get_strings_from_cfg() {
# Grabs strings from CFG files.
# Usage: _get_strings_from_cfg "$@" (array of files)
# Returns: $<language_code>_strings $cfg_list (arrays)
local file name
for file in "$@"; do
name=${file##*/}; name="${name/.cfg/_strings}"
mapfile -t "$name" < "$file"
[[ $name != en_strings ]] && cfg_list+=("$name")
done
}
_get_string_data() {
# Grabs string name and string value
# Returns: $data (array)
IFS=$'\n' read -d "" -ra data <<< "${1//=/$'\n'}"
data[1]=${data[1]//\"}
}
_translate_string() {
# Usage: _translate_string "string" "language code"
# Returns: $translated (string)
translated="$(curl -s https://api-free.deepl.com/v2/translate \
-d auth_key=f1414922-db81-5454-67bd-9608cdca44b3:fx \
-d "text=$1" -d "target_lang=${2^^}" \
| grep -o '"text":"[^"]*' | grep -o '[^"]*$')"
}
_translate_and_add_missing_strings_into_cfg() {
# Translates then write missing strings from base language
# into the various translation files (from $cfg_list).
local line language trad_strings
for line in "${en_strings[@]:?}"; do
_get_string_data "$line"
for language in "${cfg_list[@]}"; do
declare -n trad_strings="$language"
if [[ "${trad_strings[*]}" != *"${data[0]}="* ]]; then
_translate_string "${data[1]}" "${language/_strings}"
[[ -n $translated ]] && line="${data[0]}=\"${translated}\""
[[ -n $translated ]] && note="translated" || note="original"
trad_strings+=("$line"); file="${language/_strings/.cfg}"
printf "%s\n" "${trad_strings[@]}" > "lang/$file"
echo "=> ${data[0]} (${note}) added into $file"
fi
done
done
}
# Run auto-translate.
if [[ $1 == dh ]]; then
echo "Running auto-translate (this could take a while)..."
_clean_cfg_files lang/*.cfg
_get_strings_from_cfg lang/*.cfg
_translate_and_add_missing_strings_into_cfg
_clean_cfg_files lang/*.cfg
[[ $note ]] && echo "==> done" || echo "==> nothing to translate"
else
echo "ERROR: you must specify 'dh' as argument"
fi

View File

@ -1,6 +0,0 @@
[Desktop Entry]
Type=Application
Name=1st Run
Exec=1stRun.sh
Icon=/usr/share/icons/distroicons/tux.svg
Categories=System;Virtualization;Settings;

View File

@ -1,123 +0,0 @@
#!/bin/bash
source distrohopper.conf
# config path
CONFIG_DIR="$HOME/.config/distrohopper"
create_structure() {
# create default dirs
mkdir -p "$CONFIG_DIR"
sudo mkdir -p "$ICON_DIR"
# copy everything to config dir
cp -r * "$CONFIG_DIR/"
# move icons
sudo mv "$CONFIG_DIR/icons/"* "$ICON_DIR/"
rm -r "$CONFIG_DIR/icons"
}
# Set VMs dir
set_dir() {
NEWDIR="$(yad --file --directory --title="Where to save VMs?")"
VMS_DIR="$NEWDIR"
echo "VMS_DIR=\"$VMS_DIR\"
export \"VMS_DIR\"" >> "$CONFIG_DIR/distrohopper.conf"
export "VMS_DIR"
echo "New dir is: $VMS_DIR"
}
# install prerequisities
install_prereq() {
# (Void linux)
sudo xbps-install -S qemu bash coreutils grep jq procps-ng python3 util-linux sed spice-gtk swtpm usbutils wget xdg-user-dirs xrandr unzip zsync socat
}
# Install distrohopper to all users
install_dh() {
sudo cp ../dh ../quickget ../quickemu ../macrecovery ../windowskey /usr/bin/
}
# Renew VMs
renew_ready() {
echo "Updating VMs..."
source "$CONFIG_DIR/distrohopper.conf"
# Enter ditrohopper VMs dir
cd "$VMS_DIR" || exit
# check for VMs .conf files (ready to run VMs)
for vm_conf in *.conf; do
vm_desktop=$(basename "$VMS_DIR/$vm_conf" .conf)
# Use fuzzy matching to find the best matching icon file (ready to run VMs)
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f -2)
icon_file=$(find "$ICON_DIR" -type f -iname "${icon_name// /}.*")
# If no icon was found, try shorter name (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f1)
icon_file=$(find "$ICON_DIR" -type f -iname "${icon_name// /}.*")
fi
# If no icon was found, use a default icon (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_file="$ICON_DIR/tux.svg"
fi
# content of desktop files (ready to run VMs)
desktop_file_content="[Desktop Entry]
Type=Application
Name=$vm_desktop
Exec=sh -c 'cd \"$VMS_DIR\" && quickemu -vm \"$vm_conf\"'
Icon=$icon_file
Categories=System;Virtualization;"
# create desktop files (ready to run VMs)
echo "$desktop_file_content" > "$CONFIG_DIR"/ready/"$vm_desktop".desktop
done
}
renew_supported() {
# get supported VMs
quickget | sed 1d | cut -d':' -f2 | grep -o '[^ ]*' > "$CONFIG_DIR/supported.md"
while read -r get_name; do
vm_desktop=$(echo "$get_name" | tr ' ' '_')
releases=$(quickget "$vm_desktop" | grep 'Releases' | cut -d':' -f2 | sed 's/^ //')
editions=$(quickget "$vm_desktop" | grep 'Editions' | cut -d':' -f2 | sed 's/^ //')
icon_name="$ICON_DIR/$get_name"
if [ -f "$icon_name.svg" ]; then
icon_file="$icon_name.svg"
elif [ -f "$icon_name.png" ]; then
icon_file="$icon_name.png"
else
icon_file="$ICON_DIR/tux.svg"
fi
# Check if there are editions
if [ -z "$editions" ]; then
# Create desktop file for VMs without editions
desktop_file_content="[Desktop Entry]
Type=Application
Name=$get_name
releases=$releases
replace=$replace
Exec=sh -c 'cd \"$VMS_DIR\" && yad --form --field=\"Release:CB\" \"${releases// /$replace}\" | cut -d\"|\" -f1 | xargs -I{} sh -c \"quickget $get_name {}\"'
Icon=$icon_file
Categories=System;Virtualization;"
echo "$desktop_file_content" > "$CONFIG_DIR"/supported/"$vm_desktop".desktop
else
# Create desktop file for VMs with editions
desktop_file_content="[Desktop Entry]
Type=Application
Name=$get_name
releases=$releases
editions=$editions
replace=$replace
Exec=sh -c 'cd \"$VMS_DIR\" && yad --form --separator=\" \" --field=\"Release:CB\" \"${releases// /$replace}\" --field=\"Edition:CB\" \"${editions// /$replace}\" | xargs -I{} sh -c \"quickget $get_name {}\"'
Icon=$icon_file
Categories=System;Virtualization;"
echo "$desktop_file_content" > "$CONFIG_DIR"/supported/"$vm_desktop".desktop
fi
done < "$CONFIG_DIR"/supported.md
}
set_dir
create_structure
install_prereq
install_dh
renew_supported
renew_ready
echo "Done"

View File

@ -1,6 +0,0 @@
[Desktop Entry]
Type=Application
Name=Add new distro
Exec=add_distro.sh
Icon=/usr/share/icons/distroicons/cereus.svg
Categories=System;Virtualization;Settings;

View File

@ -1,31 +0,0 @@
#!/bin/bash
TMP_DIR="/tmp"
yad --form --field="Pretty name" "" --field="Name" "" --field="Releases" "" --field="Editions" "" --field="URL" "" --field="ISO" "" --field="Checksum file" "" > ${TMP_DIR}/template.tmp
PRETTY_NAME="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f1)"
NAME="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f2)"
RELEASES="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f3)"
EDITIONS="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f4)"
URL="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f5)"
ISO="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f6)"
CHECKSUM_FILE="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f7)"
echo " $NAME) PRETTY_NAME=$PRETTY_NAME;;
" > ${TMP_DIR}/${NAME}.tmp
{ echo " $NAME \\
"; echo "function releases_$NAME() {
echo $RELEASES
}
"; echo "function editions_$NAME() {
echo $EDITIONS
}
"; echo "function get_$NAME() {
local EDITION="${1:-}"
local HASH=""
local ISO="$ISO"
local URL="$URL"
HASH=\"$(wget -q -O- "${URL}/${CHECKSUM_FILE}" | grep "(${ISO}" | cut -d' ' -f4)\"
echo \"${URL}/${ISO} ${HASH}\"
}
"; } >> ${TMP_DIR}/${NAME}.tmp
meld ${TMP_DIR}/${NAME}.tmp ../quickget

View File

@ -1,19 +0,0 @@
#!/bin/bash
# DEBUG mod
#bash -x quickyad 2>&1 | tee output.log
# YAD gui script for excellent quickemu
#TODO Download Icons
#TODO Add homepages to right click
echo "Running..."
# dependencies checks
if ! command -v yad >/dev/null 2>&1; then
echo "You are missing yad..." >&2
exit 1
fi
if ! command -v quickemu >/dev/null 2>&1; then
echo "You are missing quickemu..." >&2
exit 1
fi

View File

@ -1,5 +0,0 @@
ICON_DIR="/usr/share/icons/distroicons"
TERMINAL=sakura
replace='"!"'
export "CONFIG_DIR" "ICON_DIR" "TERMINAL" "replace"

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

View File

@ -1,12 +0,0 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg width="512px" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 65 65" version="1.1" height="512px">
<defs>
<linearGradient id="lg" y1="26.924%" x2="28.129%" x1="54.638%" y2="79.519%">
<stop stop-color="#fff" stop-opacity="0" offset="0"/>
<stop stop-color="#fff" stop-opacity=".27451" offset="1"/>
</linearGradient>
</defs>
<path d="m32.253 0.20991c-2.849 6.9843-4.579 11.559-7.75 18.336 1.944 2.061 4.334 4.453 8.211 7.164-4.168-1.715-7.009-3.432-9.133-5.219-4.059 8.47-10.423 20.531-23.328 43.719 10.14-5.854 18.002-9.466 25.328-10.844-0.314-1.351-0.481-2.819-0.469-4.344l0.008-0.32c0.161-6.498 3.542-11.495 7.547-11.156 4.004 0.339 7.122 5.884 6.961 12.383-0.031 1.224-0.173 2.4-0.414 3.492 7.247 1.418 15.034 5.013 25.039 10.789-1.973-3.632-3.74-6.905-5.422-10.024-2.649-2.053-5.411-4.724-11.047-7.617 3.874 1.007 6.65 2.171 8.812 3.469-17.098-31.835-18.48-36.068-24.343-49.828v-0.00009z" fill="#1793D1"/>
<path id="path2522" fill-opacity=".16568" fill="#fff" d="m50.266 38.249c-13.872-18.827-17.087-34.002-17.902-37.625 7.4 17.067 7.349 17.277 17.902 37.625z"/>
<path d="m32.378 0.45992c-0.36 0.88448-0.7 1.7468-1.032 2.5625-0.364 0.8946-0.718 1.7565-1.062 2.5938s-0.693 1.6309-1.031 2.4375c-0.339 0.8065-0.654 1.6039-1 2.4063-0.346 0.802-0.726 1.613-1.094 2.437-0.368 0.825-0.752 1.658-1.156 2.532-0.404 0.873-0.828 1.801-1.282 2.75-0.061 0.128-0.124 0.276-0.187 0.406 1.939 2.054 4.33 4.427 8.187 7.125-4.167-1.715-7-3.432-9.125-5.219-0.11 0.226-0.198 0.425-0.312 0.656-0.42 0.871-0.871 1.733-1.344 2.688-0.113 0.224-0.196 0.427-0.312 0.656-0.501 1.004-1.026 2.043-1.594 3.156-0.113 0.22-0.228 0.402-0.344 0.625-0.343 0.667-1.44 2.77-2.562 4.907-0.655 1.248-1.169 2.27-1.907 3.656-0.209 0.398-0.639 1.195-0.75 1.406 8.125-4.573 16.891-11.216 32.813-5.531-0.797-1.51-1.562-2.919-2.25-4.25-0.688-1.332-1.312-2.571-1.906-3.75s-1.143-2.291-1.657-3.344c-0.513-1.053-0.989-2.047-1.437-3s-0.885-1.87-1.281-2.75c-0.397-0.879-0.766-1.73-1.125-2.562-0.359-0.833-0.695-1.658-1.032-2.469-0.336-0.8115-0.672-1.5896-1-2.4063-0.142-0.3554-0.263-0.7338-0.406-1.0938-0.888-2.0849-1.759-4.1515-2.812-6.625v0.00002z" fill="url(#lg)"/>
</svg>

Before

Width:  |  Height:  |  Size: 2.2 KiB

File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 667 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.3 KiB

View File

@ -1,63 +0,0 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
width="512"
height="512"
version="1.1"
id="svg12"
sodipodi:docname="mx.svg"
inkscape:version="1.1.1 (3bf5ae0d25, 2021-09-20)"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns="http://www.w3.org/2000/svg"
xmlns:svg="http://www.w3.org/2000/svg">
<defs
id="defs16" />
<sodipodi:namedview
id="namedview14"
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1.0"
inkscape:pageshadow="2"
inkscape:pageopacity="0.0"
inkscape:pagecheckerboard="0"
showgrid="false"
inkscape:zoom="1.7050781"
inkscape:cx="251.30813"
inkscape:cy="256"
inkscape:window-width="3440"
inkscape:window-height="1417"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="1"
inkscape:current-layer="svg12" />
<rect
style="opacity:0.2;stroke-width:8.77193"
width="491.22806"
height="491.22806"
x="8.9861288"
y="14.359788"
rx="24.561403"
ry="24.561403"
id="rect2" />
<rect
style="fill:#4f4f4f;stroke-width:8.77193"
width="491.22806"
height="491.22806"
x="8.9861288"
y="5.5878611"
rx="24.561403"
ry="24.561403"
id="rect4" />
<path
style="opacity:0.1;fill:#ffffff;stroke-width:8.77193"
d="m 33.554547,5.5878611 c -13.60702,0 -24.5684295,10.9613999 -24.5684295,24.5684199 v 8.77193 c 0,-13.60702 10.9614095,-24.56842 24.5684295,-24.56842 H 475.64402 c 13.60526,0 24.57018,10.9614 24.57018,24.56842 v -8.77193 c 0,-13.60702 -10.96492,-24.5684199 -24.57018,-24.5684199 z"
id="path6" />
<path
style="opacity:0.2;stroke-width:8.77193"
d="m 175.65279,119.62295 -35.08772,35.08772 96.85088,108.96491 -19.5614,23.00877 -24.6579,-26.71053 L 61.617697,409.09663 H 447.58262 l -87.7193,-105.26316 -10.1579,11.59649 -63.28947,-71.20175 90.99123,-107.0614 -17.54386,-17.54386 -90.05263,105.92982 z m 78.36842,162.72807 62.80702,70.64912 -18.36842,21.00877 -63.70175,-69.00877 z"
id="path8" />
<path
style="fill:#ffffff;stroke-width:8.77193"
d="m 175.65279,110.85102 -35.08772,35.08772 96.85088,108.96491 -19.5614,23.00877 -24.6579,-26.71053 L 61.617697,400.3247 H 447.58262 l -87.7193,-105.26316 -10.1579,11.59649 -63.28947,-71.20175 90.99123,-107.0614 -17.54386,-17.54386 -90.05263,105.92982 z m 78.36842,162.72807 62.80702,70.64912 -18.36842,21.00877 -63.70175,-69.00877 z"
id="path10" />
</svg>

Before

Width:  |  Height:  |  Size: 2.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 9.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.2 KiB

View File

@ -1,7 +0,0 @@
[Desktop Entry]
Type=Application
Name=ISOs copy
Exec=iso_copy.sh
Icon=copy.svg
Comment=Copy all ISOs to target dir
Categories=System;Virtualization;Settings;

View File

@ -1,9 +0,0 @@
#!/usr/bin/bash
CONFIG_DIR="$HOME"/.config/distrohopper
source "$CONFIG_DIR"/distrohopper.conf
yad --file --directory > target
echo "It will take while..."
cd "$VMS_DIR" || exit 1
cp */*.iso "$target"
echo "Done"

View File

@ -1,6 +0,0 @@
[Desktop Entry]
Type=Application
Name=Renew VMs
Exec=renew.sh
Icon=/usr/share/icons/distroicons/tux.svg
Categories=System;Virtualization;Settings;

View File

@ -1,84 +0,0 @@
#!/bin/bash
# config path
CONFIG_DIR="$HOME/.config/distrohopper"
source "$CONFIG_DIR"/distrohopper.conf
# Renew VMs
renew_ready() {
echo "Updating VMs..."
# Enter ditrohopper VMs dir
cd "$VMS_DIR" || exit
# check for VMs .conf files (ready to run VMs)
for vm_conf in *.conf; do
vm_desktop=$(basename "$VMS_DIR/$vm_conf" .conf)
# Use fuzzy matching to find the best matching icon file (ready to run VMs)
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f -2)
icon_file=$(find "$ICON_DIR" -type f -iname "${icon_name// /}.*")
# If no icon was found, try shorter name (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f1)
icon_file=$(find "$ICON_DIR" -type f -iname "${icon_name// /}.*")
fi
# If no icon was found, use a default icon (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_file="$ICON_DIR/tux.svg"
fi
# content of desktop files (ready to run VMs)
desktop_file_content="[Desktop Entry]
Type=Application
Name=$vm_desktop
Exec=sh -c 'cd \"$VMS_DIR\" && quickemu -vm \"$vm_conf\"'
Icon=$icon_file
Categories=System;Virtualization;"
# create desktop files (ready to run VMs)
echo "$desktop_file_content" > "$CONFIG_DIR"/ready/"$vm_desktop".desktop
done
}
renew_supported() {
# get supported VMs
quickget | sed 1d | cut -d':' -f2 | grep -o '[^ ]*' > "$CONFIG_DIR/supported.md"
while read -r get_name; do
vm_desktop=$(echo "$get_name" | tr ' ' '_')
releases=$(quickget "$vm_desktop" | grep 'Releases' | cut -d':' -f2 | sed 's/^ //')
editions=$(quickget "$vm_desktop" | grep 'Editions' | cut -d':' -f2 | sed 's/^ //')
icon_name="$ICON_DIR/$get_name"
if [ -f "$icon_name.svg" ]; then
icon_file="$icon_name.svg"
elif [ -f "$icon_name.png" ]; then
icon_file="$icon_name.png"
else
icon_file="$ICON_DIR/tux.svg"
fi
# Check if there are editions
if [ -z "$editions" ]; then
# Create desktop file for VMs without editions
desktop_file_content="[Desktop Entry]
Type=Application
Name=$get_name
releases=$releases
replace=$replace
Exec=sh -c 'cd \"$VMS_DIR\" && yad --form --field=\"Release:CB\" \"${releases// /$replace}\" | cut -d\"|\" -f1 | xargs -I{} sh -c \"quickget $get_name {}\"'
Icon=$icon_file
Categories=System;Virtualization;"
echo "$desktop_file_content" > "$CONFIG_DIR"/supported/"$vm_desktop".desktop
else
# Create desktop file for VMs with editions
desktop_file_content="[Desktop Entry]
Type=Application
Name=$get_name
releases=$releases
editions=$editions
replace=$replace
Exec=sh -c 'cd \"$VMS_DIR\" && yad --form --separator=\" \" --field=\"Release:CB\" \"${releases// /$replace}\" --field=\"Edition:CB\" \"${editions// /$replace}\" | xargs -I{} sh -c \"quickget $get_name {}\"'
Icon=$icon_file
Categories=System;Virtualization;"
echo "$desktop_file_content" > "$CONFIG_DIR"/supported/"$vm_desktop".desktop
fi
done < "$CONFIG_DIR"/supported.md
}
renew_supported
renew_ready
echo "Done"

View File

@ -1,6 +0,0 @@
[Desktop Entry]
Type=Application
Name=Set VMs dir
Exec=set_dir.sh
Icon=/usr/share/icons/distroicons/cereus.svg
Categories=System;Virtualization;Settings;

View File

@ -1,12 +0,0 @@
#!/bin/bash
source distrohopper.conf
NEWDIR="$(yad --file --directory --title="Where to save VMs?")"
VMS_DIR="$NEWDIR"
echo "VMS_DIR=\"$VMS_DIR\"
export \"VMS_DIR\"" >> distrohopper.conf
export VMS_DIR
echo "New dir is: $VMS_DIR"

View File

@ -1,17 +0,0 @@
#!/bin/bash
# Get the name of the script from the command line argument
script_name=$1
# Get a list of all the function names in the script
function_names=$(grep -oP '^[[:space:]]*function \K\w+' "$script_name")
# Sort the function names alphabetically
sorted_function_names=$(echo "$function_names" | sort)
# Loop through the sorted function names and print the function definitions
for function_name in $sorted_function_names
do
# Print the function definition to stdout
grep -A $(wc -l < "$script_name") -w "function $function_name" "$script_name"
done

884
dh
View File

@ -1,115 +1,781 @@
#!/bin/bash
export LC_ALL=C
#!/usr/bin/env bash
# shellcheck disable=1078,1079,1091,2027,2034
progname="${progname:="${0##*/}"}"
version="0.4"
GTK_THEME="alt-dialog"
CONFIG_DIR="$HOME/.config/distrohopper"
ICON_DIR="/usr/share/icons/distroicons"
TERMINAL=sakura
replace='"!"'
export "CONFIG_DIR" "ICON_DIR" "TERMINAL" "replace"
cd "$VMS_DIR" || exit
#source "$CONFIG_DIR/distrohopper.conf"
# Set traps to catch the signals and exit gracefully
trap "exit" INT
trap "exit" EXIT
#TODO Add homepages to right click
#printf '%s: v.%s\nquickemu: v.%s\n\n Work dir.: %s\n\n Prepared VMs:\n-------------\n' "$progname" "$version" "$(quickemu --version)" "$(pwd)"
# dependencies checks
if ! command -v yad >/dev/null 2>&1; then
echo "You are missing yad..." >&2
exit 1
# shellcheck source=/dev/null
if [[ -f "lang/${LANGUAGE}.cfg" ]]; then
source "lang/${LANGUAGE}.cfg"
elif [[ -f "lang/${LANG:0:5}.cfg" ]]; then
source "lang/${LANG:0:5}.cfg"
elif [[ -f "lang/${LANG:0:2}.cfg" ]]; then
source "lang/${LANG:0:2}.cfg"
else
source "lang/en.cfg"
fi
# run TUI instead
if [ "$1" = "-t" ] ; then
printf '%s: v.%s\nquickemu: v.%s\n\n VMs dir: %s\n\n' "$progname" "$version" "$(quickemu --version)" "$(pwd)"
vms=(*.conf)
# Dependency check: check if fzf is installed and can be executed
if ! command -v fzf >/dev/null 2>&1; then
echo "You are missing fzf..." && exit 255
fi
printf ' Prepared VMs:\n-------------\n\n'
# Check if there are any VMs
if [ ${#vms[@]} -eq 0 ]; then
echo "No VMs found."
exit 1
fi
# Print the names of the available VMs
printf "%s\n" "${vms[@]%.*}"
echo "-------------"
# Action prompt
printf " Do you want to create a new VM? (c)
or run an existing one? (press anything)\n"
read -rn 1 -s start
case $start in
c )
todo="create"
;;
esac
# If the user chose to create a new VM
if [ "$todo" = "create" ]; then
os=$(quickget | sed 1d | cut -d':' -f2 | grep -o '[^ ]*' | fzf --cycle --header='Choose OS to download
or CTRL-c or ESC to quit')
# If the OS is Windows
if [ "$os" = windows ]; then
answer=$(echo "Default English
Choose other language" | fzf --cycle)
# If the user wants another windows language
trap 'exit' SIGINT SIGTERM SIGQUIT
set -e
echo "$MSG_RUNNING"
function variables_set() {
# DEBUG mod
#bash -x ./dh 2>&1 | tee output.log
#progname="${progname:="${0##*/}"}"
progname="DistroHopper"
version="0.80"
#GTK_THEME="alt-dialog"
DH_CONFIG_DIR="$HOME/.config/distrohopper"
DH_CONFIG="$DH_CONFIG_DIR/distrohopper.conf"
DH_ICON_DIR="/usr/share/icons/distrohopper"
PATH_PREFIX="/usr/bin/"
TMP_DIR="/tmp"
terminal="sakura"
replace='"!"'
#export "DH_CONFIG_DIR" "DH_CONFIG" "replace" "DH_ICON_DIR" "PATH_PREFIX" "TMP_DIR" "terminal"
check_and_set_mode
# Set traps to catch the signals and exit gracefully
trap "exit" INT
trap "exit" EXIT
}
function bugs_notice_show() {
echo ""
echo "$MSG_DONE"
echo ""
echo "$MSG_BUGS"
echo "$MSG_FEEDBACK"
echo "$MSG_LIKE"
echo "$MSG_IMPROVE"
echo "$MSG_KNOW"
echo ""
echo "$MSG_FLAWLESS"
echo " zenobit"
}
function help_show() {
echo "DistroHopper v. $version"
echo "quickemu v. $("$portable_prefix"quickemu --version)"
printf "$MSG_H_FIRST ./dh i && dh s g\n"
echo "$MSG_ARGUMENTS"
printf $"\th\thelp\t\t\t$MSG_H_HELP\n"
echo "---------------------------------------------------------"
printf $"\td\tdir\t\t\t$MSG_H_DIR\n"
printf $"\ti\tinstall\t\t\t$MSG_H_INSTALL\n"
echo "---------------------------------------------------------"
printf $"\tm\tmode\t\t\t$MSG_H_MODE\n"
echo "---------------------------------------------------------"
printf $"\ts\tsupported\t\t$MSG_H_SUPPORTED\n"
printf $"\tr\tready\t\t\t$MSG_H_READY\n"
echo "---------------------------------------------------------"
printf $"\tt\ttui\t\t\t$MSG_H_TUI\n"
printf $"\tg\tgui\t\t\t$MSG_H_GUI\n"
echo "---------------------------------------------------------"
printf $"\ta\tadd\t\t\t$MSG_H_ADD\n"
printf $"\tf\tfunctions\t\t$MSG_H_SORT\n"
printf $"\tp\tpush\t\t\t$MSG_H_PUSH\n"
echo "---------------------------------------------------------"
printf $"\tc\tcopy\t\t\t$MSG_H_COPY\n"
echo "---------------------------------------------------------"
printf $"\tl\tlanguage\t\t$MSG_H_TRANSLATE\n"
echo "---------------------------------------------------------"
echo "$MSG_HOMEPAGE"
echo "$MSG_HOSTED"
echo "$MSG_CHAT"
}
function check_and_set_mode() {
[ -f "$DH_CONFIG" ] && work_in_choosed_dir || work_in_current_dir
}
function work_in_current_dir() {
VMS_DIR="./"
DH_CONFIG_DIR="./"
DH_ICON_DIR="./icons"
portable_prefix='./'
#export "VMS_DIR" "DH_CONFIG_DIR" "DH_ICON_DIR" "terminal" "replace" "portable_prefix"
}
function work_in_choosed_dir() {
# shellcheck source=distrohopper.conf
source "$DH_CONFIG"
portable_prefix=''
#export "portable_prefix"
}
# installation ---------------------------------------------------------
function dependencies_check_gui() {
[ -f "$PATH_PREFIX/yad" ] || echo "$MSG_YAD"
}
function dependencies_check_tui() {
[ -f "$PATH_PREFIX/fzf" ] || echo "$MSG_FZF"
}
function desktop_entry_create() {
cat <<EOF > ${DESKTOP_FILE}
[Desktop Entry]
Version=$version
Type=$type
Name=$name
GenericName=$gname
Comment=$comment
Exec=$execmd
Icon=$icon
Terminal=$terminal
X-MultipleArgs=$args
Type=$type
Categories=$categories
StartupNotify=$notify
MimeType=$mime
Keywords=$keyword
EOF
}
function directory_structure_create() {
source distrohopper.conf
echo "$MSG_CONFIG"
mkdir -p "$DH_CONFIG_DIR"
echo "$MSG_ICONS"
mkdir -p "$DH_ICON_DIR" >/dev/null 2>&1 || sudo mkdir -p "$DH_ICON_DIR"
}
function desktop_entry_distrohopper() {
echo "$MSG_INTERM"
run_in_terminal
DESKTOP_FILE="${TMP_DIR}/dh.desktop"
type='Application'
name='DistroHopper'
comment='Quickly download, create and run VM of any#TODO operating system.'
version="${version}"
execmd="sh -c 'cd ${VMS_DIR} && dh g'"
if [ "$interminal" == "yes" ]; then
terminal='true'
fi
icon="$DH_ICON_DIR/hop.svg"
categories='System;Virtualization;'
desktop_entry_create
sudo cp ${TMP_DIR}/dh.desktop /usr/share/applications/
}
function virtual_machines_directory_choose() {
NEWDIR="$(yad --width=900 --height=900 --file --directory --title="Where to save VMs?")"
VMS_DIR="$NEWDIR"
echo "VMS_DIR=\"$VMS_DIR\"
export \"VMS_DIR\"" >> "$DH_CONFIG"
}
function dependencies_install() {
# Find the current distribution and install dependecies
if [ -f /etc/os-release ]; then
if [ -f "$PATH_PREFIX/pacman" ]; then
install_needed_pacman
elif [ -f "$PATH_PREFIX/apt" ]; then
install_needed_apt
elif [ -f "$PATH_PREFIX/xbps-install" ]; then
install_needed_xbps
elif [ -f "$PATH_PREFIX/dnf" ]; then
install_needed_dnf
else
echo "$MSG_ERROR: $MSG_NO_DISTRO"
exit 1
fi
fi
}
function install_needed_atp() {
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip yad fzf
}
function install_needed_pacman() {
sudo pacman -S cdrtools coreutils edk2-ovmf grep jq procps python3 qemu-full sed socat spice-gtk swtpm usbutils util-linux wget xdg-user-dirs xorg-xrandr zsync getext yad fzf
}
function install_needed_xbps() {
sudo xbps-install -S qemu bash coreutils grep jq procps-ng python3 util-linux sed spice-gtk swtpm usbutils wget xdg-user-dirs xrandr unzip zsync socat yad fzf
}
function install_needed_dnf() {
sudo dnf install qemu bash coreutils edk2-tools grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-gtk-tools swtpm wget xdg-user-dirs xrandr unzip yad fzf
}
function distrohopper_install() {
cp dh quickget quickemu macrecovery windowskey "$PATH_PREFIX" >/dev/null 2>&1 || sudo cp dh quickget quickemu macrecovery windowskey "$PATH_PREFIX"
# quickget also to config directory for adding new distros...
cp quickget "$DH_CONFIG_DIR/"
echo "$MSG_C_ICONS"
cp icons/* "$DH_ICON_DIR/" >/dev/null 2>&1 || sudo cp icons/* "$DH_ICON_DIR/"
echo "$MSG_C_ENTRIES"
cp -r ready "$DH_CONFIG_DIR/"
cp -r supported "$DH_CONFIG_DIR/"
cp -r lang "$DH_CONFIG_DIR/"
}
function installation_process() {
dependencies_check_tui
dependencies_check_gui
echo "$MSG_NEEDED"
dependencies_install
echo "$MSG_STRUCTURE" \
&& directory_structure_create \
&& echo "$MSG_SETTINGUP" \
&& virtual_machines_directory_choose \
&& echo "$MSG_INSTALLING" \
&& distrohopper_install \
&& echo "$MSG_C_ENTRY" \
&& desktop_entry_distrohopper
}
# basic ----------------------------------------------------------------
function run_in_terminal() {
read -r response
if [[ "$response" =~ ^[YyAa]$ ]]; then
interminal="yes"
else
interminal="no"
fi
}
function virtual_machines_update_ready() {
cd "$VMS_DIR" || exit 1
rm "$DH_CONFIG_DIR"/ready/*.desktop 2>/dev/null
for vm_conf in $(pwd)
do
if [ "${vm_conf}" == "distrohopper.conf" ]; then
echo "continue" # skip processing distrohopper.conf
fi
echo "creating..."
vm_desktop=$(basename "$VMS_DIR/$vm_conf" .conf)
# Use fuzzy matching to find the best matching icon file (ready to run VMs)
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f -2)
icon_file=$(find "$DH_ICON_DIR" -type f -iname "${icon_name// /}.*")
# If no icon was found, try shorter name (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f1)
icon_file=$(find "$DH_ICON_DIR" -type f -iname "${icon_name// /}.*")
elif [ -z "$icon_file" ]; then
icon_file="$DH_ICON_DIR/tux.svg"
fi
DESKTOP_FILE="${DH_CONFIG_DIR}/ready/${vm_desktop}.desktop"
type='Application'
name="${vm_desktop}"
comment='Quickly download, create and run VM of any#TODO operating system.'
version="${version}"
execmd="sh -c 'cd ${VMS_DIR} && ${portable_prefix}quickemu -vm ${vm_conf};$SHELL'"
icon="${icon_file}"
categories='System;Virtualization;'
desktop_entry_create
done
}
function renew_ready() {
cd "$VMS_DIR" || exit 1
# for files in "$VMS_DIR"/*; do
# if [ ! -e *.conf ]; then
# echo $"No .conf files found"
# return
# fi
for vm_conf in *.conf; do
if [ "$vm_conf" == "distrohopper.conf" ]; then
continue # skip processing distrohopper.conf
fi
vm_desktop=$(basename "$VMS_DIR/$vm_conf" .conf)
# Use fuzzy matching to find the best matching icon file (ready to run VMs)
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f -2)
icon_file=$(find "$DH_ICON_DIR" -type f -iname "${icon_name// /}.*")
# If no icon was found, try shorter name (ready to run VMs)
if [ -z "$icon_file" ]; then
icon_name=$(basename "$VMS_DIR/$vm_conf" .conf | cut -d'-' -f1)
icon_file=$(find "$DH_ICON_DIR" -type f -iname "${icon_name// /}.*")
elif [ -z "$icon_file" ]; then
icon_file="$DH_ICON_DIR/tux.svg"
fi
# content of desktop files (ready to run VMs)
cat <<EOF > "$DH_CONFIG_DIR"/ready/"$vm_desktop".desktop
[Desktop Entry]
Type=Application
Name=$vm_desktop
Exec=sh -c 'cd ${VMS_DIR} && ${portable_prefix}quickemu -vm ${vm_conf}'
Icon=$icon_file
Categories=System;Virtualization;
EOF
done
}
function virtual_machines_update_supported() {
rm "$DH_CONFIG_DIR"/supported/*.desktop
echo "$MSG_INTERM"
run_in_terminal
# get supported VMs
"$portable_prefix"quickget | sed 1d | cut -d':' -f2 | grep -o '[^ ]*' > "$DH_CONFIG_DIR/supported.md"
while read -r get_name; do
vm_desktop=$(echo "$get_name" | tr ' ' '_')
releases=$("$portable_prefix"quickget "$vm_desktop" | grep 'Releases' | cut -d':' -f2 | sed 's/^ //' | sed 's/ *$//')
editions=$("$portable_prefix"quickget "$vm_desktop" | grep 'Editions' | cut -d':' -f2 | sed 's/^ //' | sed 's/ *$//')
icon_name="$DH_ICON_DIR/$get_name"
if [ -f "$icon_name.svg" ]; then
icon_file="$icon_name.svg"
elif [ -f "$icon_name.png" ]; then
icon_file="$icon_name.png"
else
icon_file="$DH_ICON_DIR/tux.svg"
fi
echo "$MSG_CREATING $vm_desktop $MSG_DESKTOP_ENTRY"
echo ""
# Check if there are editions
DESKTOP_FILE="$DH_CONFIG_DIR/supported/$vm_desktop.desktop"
type="Application"
name="$get_name"
if [ -z "$editions" ]; then
execmd="sh -c 'cd ${VMS_DIR} && yad --form --field=\"Release:CB\" \"${releases// /$replace}\" | cut -d\"|\" -f1 | xargs -I{} sh -c \"${portable_prefix}quickget ${get_name} {}\";$SHELL'"
elif [ "$interminal" == "yes" ]; then
terminal="true"
else
execmd="sh -c 'cd ${VMS_DIR} && yad --form --separator=\" \" --field=\"Release:CB\" \"${releases// /$replace}\" --field=\"Edition:CB\" \"${editions// /$replace}\" | xargs -I{} sh -c \"${portable_prefix}quickget ${get_name} {}\";$SHELL'"
fi
icon="$icon_file"
categories='System;Virtualization;'
desktop_entry_create
done < "$DH_CONFIG_DIR"/supported.md
}
function distrohopper_run_gui() {
dependencies_check_gui
key=$((RANDOM % 9000 + 1000))
yad --plug="$key" --tabnum=1 --monitor --icons --listen --read-dir="$DH_CONFIG_DIR"/ready --sort-by-name --no-buttons --borders=0 --icon-size=46 --item-width=76 &
yad --plug="$key" --tabnum=2 --monitor --icons --listen --read-dir="$DH_CONFIG_DIR"/supported --sort-by-name --no-buttons --borders=0 --icon-size=46 --item-width=76 &
yad --dynamic --notebook --key="$key" --monitor --listen --window-icon="$DH_ICON_DIR"/hop.svg --width=900 --height=900 --title="DistroHopper" --tab="run VM" --tab="download VM"
}
function WIP_buttons() {
#define functions for buttons
ABOUT="distrohopper_about"
HELP="help_show"
DIR=""
LANG=""
INSTALL=""
MODE=""
SUPPORTED=""
READY=""
TUI=""
ADD=""
SORT=""
PUSH=""
COPY=""
TRANSLATE=""
TEST=""
dependencies_check_gui
key=$((RANDOM % 9000 + 1000))
yad --plug="$key" --tabnum=1 --monitor --icons --listen --read-dir="$DH_CONFIG_DIR"/ready --sort-by-name --borders=0 --icon-size=46 --item-width=76 &
yad --plug="$key" --tabnum=2 --monitor --icons --listen --read-dir="$DH_CONFIG_DIR"/supported --sort-by-name --borders=0 --icon-size=46 --item-width=76 &
yad --plug="$key" --tabnum=3 --monitor --icons --borders=0 --icon-size=46 --item-width=76 --columns=2 --form --text-align=center \
--field="Help!!Show this help and exit":fbtn "$HELP" \
--field="Set VMs Directory!Set default directory where VMs are stored":DIR "$DIR" \
--field="Language!Enter new language string" "${lang:-$lang}" \
--field="Install DistroHopper!!Install DistroHopper":fbtn "$INSTALL" \
--field="Portable mode!Portable mode":fbtn "$MODE" \
--field="Supported!!Update supported VMs":fbtn "$SUPPORTED" \
--field="Ready!!Update ready to run VMs":fbtn "$READY" \
--field="Tui!!Run terminal user interface (TUI)":fbtn "$TUI" \
--field="Add!!Add new distro to quickget":fbtn "$ADD" \
--field="Sort!!Sort functions in quickget":fbtn "$SORT" \
--field="Push!!Push changed quickget to quickemu project #todo":fbtn "$PUSH" \
--field="Copy!!Copy all ISOs to target dir (for Ventoy)":fbtn "$COPY" \
--field="Translate DistroHopper!!Translate DistroHopper":fbtn "$TRANSLATE" \
--field="Test!!Work in Progress":fbtn "$TEST" \
--field="About!!Show info about DistroHopper":fbtn "$ABOUT" \
--button="Exit":0 &
yad --dynamic --notebook --key="$key" --monitor --listen --no-buttons \
--mouse --selectable-labels \
--window-icon="$DH_ICON_DIR/hop.svg" --width=900 --height=900 \
--title="DistroHopper" --tab="run VM" --tab="download VM" --tab="Options"
# posible: --undecorated --fixed ontop --buttons-layout=spread edge start end center --keep-icon-size --image=IMAGE --splash
VAR1="$?"
echo " DEBUG: VAR1 = $VAR1"
echo $?
}
distrohopper_about() {
yad --about --pname=DistroHopper --image="$DH_ICON_DIR"/hop.svg --pversion="$version" \
--copyright=AGPL3 --comments="random comment" --license=ALGPL3 --authors=zenobit --website=dh.osowoso.xyz \
--website-label="oSoWoSo"
}
function distrohopper_run_tui() {
dependencies_check_tui
tui_run
if [ "$todo" = "create" ]; then
virtual_machine_create
if [ "$os" = windows ]; then
tui_windows
else
quickget_get_releases_and_editions
fzf_choose_release
if [ "$(echo "$choices" | wc -l)" = 1 ]; then
quickget_download_os_release
else
fzf_choose_edition
quickget_download_os_release_edition
fi
fi
else
fzf_choose_virtual_machine_to_run
virtual_machine_run
fi
}
tui_run() {
cd "$VMS_DIR" || exit 1
vms=(*.conf)
printf "$MSG_PREPARED:\n-------------\n\n"
# Check if there are any VMs
if [ ${#vms[@]} -eq 0 ]; then
echo "$MSG_NO_VM"
exit 1
fi
# Print the names of the available VMs
printf "%s\n" "${vms[@]%.*}"
echo "-------------"
# Action prompt
echo "$MSG_NEW (c)"
printf "$MSG_OR_RUN\n"
read -rn 1 -s start
case $start in
c )
todo="create"
;;
esac
}
tui_windows() {
fzf_choose_language_windows_other
if [ "$answer" = "Choose other language" ]; then
wrelease=$(echo "8
fzf_choose_release_windows
quickget_get_windows_languages_list
fzf_choose_language_windows
quickget_download_windows
fi
}
function fzf_choose_release() {
release=$(echo "$releases" | fzf --cycle --header='Choose Release
or CTRL-c or ESC to quit')
}
function fzf_choose_edition() {
edition=$(echo "$editions" | fzf --cycle --header='Choose Edition
or CTRL-c or ESC to quit')
}
function fzf_choose_release_windows() {
wrelease=$(echo "8
10
11" | fzf --cycle)
# get window language list
wlend=$(($(cat quickget | sed '/Arabic/,$!d' | grep -n '}' | cut -d':' -f1 | head -n 1) - 1))
# get windows language
wlang=$(cat quickget | sed '/Arabic/,$!d' | head -n $wlend | cut -d'=' -f2 | tail -c +2 | head -c -2 | sed 's/^[ \t]*//' | fzf --cycle --header='Choose Language
or CTRL-c or ESC to quit')
# downloading windows
printf '\n Trying to download Windows %s %s...\n\n' "$wrelease" "$wlang"
quickget "windows" "$wrelease" "$wlang"
fi
fi
# Get the release and edition to download, if necessary
choices=$(quickget "$os" | sed 1d)
if [ "$(echo "$choices" | wc -l)" = 1 ]; then
# get release
release=$(echo "$choices" | grep 'Releases' | cut -d':' -f2 | grep -o '[^ ]*' | fzf --cycle --header='Choose Release
or CTRL-c or ESC to quit')
# downloading
printf '\n Trying to download %s %s...\n\n' "$os" "$release"
quickget "$os" "$release"
else
# get release
release=$(echo "$choices" | grep 'Releases' | cut -d':' -f2 | grep -o '[^ ]*' | fzf --cycle --header='Choose Release
or CTRL-c or ESC to quit')
# get edition
edition=$(echo "$choices" | grep 'Editions' | cut -d':' -f2 | grep -o '[^ ]*' | fzf --cycle --header='Choose Edition
or CTRL-c or ESC to quit')
# downloading
printf '\n Trying to download %s %s %s...\n\n' "$os" "$release" "$edition"
quickget "$os" "$release" "$edition"
fi
# choose VM to run
choosed=$(echo "$(ls ./***.conf 2>/dev/null | sed 's/\.conf$//')" | fzf --cycle --header='Choose VM to run
or CTRL-c or ESC to quit')
# Run choosed VM
printf '\n Starting %s...\n\n' "$choosed"
quickemu -vm "$choosed.conf"
fi
else
# run GUI
key=$((RANDOM % 9000 + 1000))
GTK_THEME="alt-dialog"
yad --plug="$key" --tabnum=1 --monitor --icons --listen --read-dir="$CONFIG_DIR"/ready --sort-by-name --no-buttons --borders=0 --icon-size=48 --item-width=76 &
yad --plug="$key" --tabnum=2 --monitor --icons --listen --read-dir="$CONFIG_DIR"/supported --sort-by-name --no-buttons --borders=0 --icon-size=48 --item-width=76 &
yad --plug="$key" --tabnum=3 --monitor --icons --listen --read-dir="$CONFIG_DIR" --sort-by-name --no-buttons --borders=0 --icon-size=48 --item-width=76 &
yad --dynamic --notebook --key="$key" --monitor --window-icon="$ICON_DIR"/hop.svg --width=900 --height=800 --title="DistroHopper $version" --listen --no-buttons --tab="run VM" --tab="download VM" --tab="settings"
fi
}
exit 0
function fzf_choose_language_windows() {
wlang=$(cat "$portable_prefix"quickget | sed '/Arabic/,$!d' | head -n $wlend | cut -d'=' -f2 | tail -c +2 | head -c -2 | sed 's/^[ \t]*//' | fzf --cycle --header='Choose Language
or CTRL-c or ESC to quit')
}
function fzf_choose_language_windows_other() {
answer=$(echo "Default English
Choose other language" | fzf --cycle)
}
function fzf_choose_virtual_machine_to_run() {
choosed=$(echo "$(ls ***.conf 2>/dev/null | sed 's/\.conf$//')" | fzf --cycle --header='Choose VM to run
or CTRL-c or ESC to quit')
}
function quickget_get_releases_and_editions() {
result=$(quickget "$choices" | sed 1d | cut -d':' -f2 | grep -o '[^ ]*')
releases=$(echo "$result" | head -1)
editions=$(echo "$result" | tail -1)
}
function quickget_get_windows_languages_list() {
wlend=$(($(cat "$portable_prefix"quickget | sed '/Arabic/,$!d' | grep -n '}' | cut -d':' -f1 | head -n 1) - 1))
}
function quickget_download_os_release() {
printf $"\n $MSG_TRYING %s %s...\n\n" "$os" "$release"
"$portable_prefix"quickget "$os" "$release"
}
function quickget_download_os_release_edition() {
printf $"\n $MSG_TRYING %s %s %s...\n\n" "$os" "$release" "$edition"
"$portable_prefix"quickget "$os" "$release" "$edition"
}
function quickget_download_windows() {
printf $"\n $MSG_TRYING %s %s...\n\n" "$wrelease" "$wlang"
"$portable_prefix"quickget "windows" "$wrelease" "$wlang"
}
function virtual_machine_create() {
os=$("$portable_prefix"quickget | sed 1d | cut -d':' -f2 | grep -o '[^ ]*' | fzf --cycle --header='Choose OS to download
or CTRL-c or ESC to quit')
}
function virtual_machine_run() {
printf $"\n $MSG_STARTING %s...\n\n" "$choosed"
"$portable_prefix"quickemu -vm "$choosed.conf"
}
# more -----------------------------------------------------------------
function TOOL_copy_ISOs_to_dir() {
yad --width=900 --height=900 --file --directory > target
cd "$VMS_DIR" || exit 1
# shellcheck disable=2154
cp ./*glob*/*.iso "$target"
}
# shellcheck disable=2086
function TOOL_quickget_add_distro() {
yad --form --field="Pretty name" "" --field="Name" "" --field="Releases" "" --field="Editions" "" --field="URL" "" --field="ISO" "" --field="Checksum file" "" > ${TMP_DIR}/template.tmp
PRETTY_NAME="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f1)"
NAME="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f2)"
RELEASES="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f3)"
EDITIONS="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f4)"
URL="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f5)"
ISO="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f6)"
CHECKSUM_FILE="$(cat ${TMP_DIR}/template.tmp | cut -d'|' -f7)"
cat <<EOF > ${TMP_DIR}/template.tmp
#32
$NAME) PRETTY_NAME="$PRETTY_NAME";;
#184+
$NAME \\
#262+
function releases_$NAME() {
echo $RELEASES
}
function editions_$NAME() {
echo $EDITIONS
}
#1052+
function get_$NAME() {
local EDITION="\${1:-}"
local HASH=""
local ISO="$ISO"
local URL="$URL"
HASH="\$(wget -q -O- \${URL}/\${CHECKSUM_FILE} | grep (\${ISO} | cut -d' ' -f4)"
echo "\${URL}/\${ISO}" "\${HASH}"
}
EOF
echo "$MSG_DONE"
meld "${TMP_DIR}"/template.tmp "$DH_CONFIG_DIR"/quickget
}
function TOOL_quickget_sort_functions() {
#TODO
# Get the name of the script from the command line argument
script_name=$1
# Get a list of all the function names in the script
function_names=$(grep -oP '^[[:space:]]*function \K\w+' "$script_name")
# Sort the function names alphabetically
sorted_function_names=$(echo "$function_names" | sort)
# Loop through the sorted function names and print the function definitions
for function_name in $sorted_function_names
do
# Print the function definition to stdout
grep -A "$(wc -l < "$script_name")" -w "function $function_name" "$script_name"
done
}
function TOOL_dh_translate() {
echo "$MSG_LANG_CHANGE"
echo "$MSG_LANG_CODE"
read lang
echo "$MSG_LANG: $lang"
echo "$MSG_DUMP"
bash --dump-po-strings dh > "$DH_CONFIG_DIR"/lang/dh-source.pot
echo "$MSG_MERGING"
meld "$DH_CONFIG_DIR"/lang/dh-source.pot "$DH_CONFIG_DIR"/lang/distrohopper-"$lang".pot
echo "$MSG_MO"
msgfmt -o "$DH_CONFIG_DIR"/lang/distrohopper-"$lang".mo "$DH_CONFIG_DIR"/lang/distrohopper-"$lang".pot
echo "$MSG_COPY $lang $MSG_TRANSLATION '/usr/share/local' $MSG_AS_ROOT"
read response
if [[ "$response" =~ ^[YyAa]$ ]]; then
echo "$MSG_C_TRANSLATION '/usr/share/local'..."
sudo cp "$DH_CONFIG_DIR"/lang/distrohopper-"$lang".mo /usr/share/lang/"$lang"/LC_MESSAGES/distrohopper.mo
fi
}
function WIP() {
echo ""
}
TOOL_set_default_terminal() {
echo "$MSG_DEFAULT_TERMINAL:"
select term in alacritty foot gnome-terminal kitty konsole mate-terminal roxterm sakura st tilix xfce4-terminal xterm custom; do
case $term in
alacritty)
export terminal=alacritty
break
;;
foot)
export terminal=foot
break
;;
gnome-terminal)
export terminal=gnome-terminal
break
;;
kitty)
export terminal=kitty
break
;;
konsole)
export terminal=konsole
break
;;
mate-terminal)
export terminal=mate-terminal
break
;;
roxterm)
export terminal=roxterm
break
;;
sakura)
export terminal=sakura
break
;;
st)
export terminal=st
break
;;
tilix)
export terminal=tilix
break
;;
xfce4-terminal)
export terminal=xfce4-terminal
break
;;
xterm)
export terminal=xterm
break
;;
custom)
read -p "Enter the command to launch your preferred terminal emulator: " custom_terminal
export terminal=$custom_terminal
break
;;
*)
echo "$MSG_INVALID_AGAIN"
;;
esac
done
echo "$MSG_TERMINAL_SET $terminal."
}
# run ------------------------------------------------------------------
while true
do
variables_set
if [[ $# -eq 0 ]]; then
printf "$MSG_NO\n\n"
help_show
fi
while [[ $# -gt 0 ]]
do
key="$1"
case $key in
h|help)
help_show
shift
;;
d|dir)
virtual_machines_directory_choose
shift
;;
i|install)
echo "$MSG_S_INSTALLATION"
installation_process
shift
;;
m|mode)
echo "$MSG_MODE"
work_in_current_dir
shift
;;
s|supported)
echo "$MSG_U_SUPPORTED"
virtual_machines_update_supported
shift
;;
r|ready)
echo "$MSG_U_READY"
#virtual_machines_update_ready
renew_ready
shift
;;
t|tui)
echo "$MSG_S_TUI"
distrohopper_run_tui
shift
;;
g|gui)
echo "$MSG_S_GUI"
distrohopper_run_gui
shift
;;
a|add)
echo "$MSG_ADD_STARTED"
TOOL_quickget_add_distro
shift
;;
f|functions)
echo "$MSG_SORTING"
TOOL_quickget_sort_functions
shift
;;
p|push)
echo "$MSG_PUSHING"
push_changes
shift
;;
c|copy)
echo "$MSG_C_ISOS"
TOOL_copy_ISOs_to_dir
shift
;;
l|language)
TOOL_dh_translate
shift
;;
z)
WIP
shift
;;
*)
echo "$MSG_INVALID: $1"
echo ""
help_show
exit 1
;;
esac
done
bugs_notice_show
exit 0
done

9
dh.desktop Executable file
View File

@ -0,0 +1,9 @@
[Desktop Entry]
Type=Application
Name=DistroHopper
Description=Quickly download, create and run VM of any#TODO operating system.
version=0.77b
Exec=sh -c './dh m g'
Icon=/home/zen/git/distrohopper/icons/hop.svg
Categories=System;Virtualization;

8
distrohopper.conf Normal file
View File

@ -0,0 +1,8 @@
DH_CONFIG_DIR="$HOME/.config/distrohopper"
DH_CONFIG="$DH_CONFIG_DIR/distrohopper.conf"
replace='"!"'
DH_ICON_DIR="/usr/share/icons/distrohopper"
PREFIX="/usr/bin/"
TERMINAL=sakura
export "DH_CONFIG_DIR" "DH_CONFIG" "replace" "DH_ICON_DIR" "PREFIX" "TERMINAL"

Binary file not shown.

Before

Width:  |  Height:  |  Size: 214 KiB

661
docs/LICENSE Normal file
View File

@ -0,0 +1,661 @@
GNU AFFERO GENERAL PUBLIC LICENSE
Version 3, 19 November 2007
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
Preamble
The GNU Affero General Public License is a free, copyleft license for
software and other kinds of works, specifically designed to ensure
cooperation with the community in the case of network server software.
The licenses for most software and other practical works are designed
to take away your freedom to share and change the works. By contrast,
our General Public Licenses are intended to guarantee your freedom to
share and change all versions of a program--to make sure it remains free
software for all its users.
When we speak of free software, we are referring to freedom, not
price. Our General Public Licenses are designed to make sure that you
have the freedom to distribute copies of free software (and charge for
them if you wish), that you receive source code or can get it if you
want it, that you can change the software or use pieces of it in new
free programs, and that you know you can do these things.
Developers that use our General Public Licenses protect your rights
with two steps: (1) assert copyright on the software, and (2) offer
you this License which gives you legal permission to copy, distribute
and/or modify the software.
A secondary benefit of defending all users' freedom is that
improvements made in alternate versions of the program, if they
receive widespread use, become available for other developers to
incorporate. Many developers of free software are heartened and
encouraged by the resulting cooperation. However, in the case of
software used on network servers, this result may fail to come about.
The GNU General Public License permits making a modified version and
letting the public access it on a server without ever releasing its
source code to the public.
The GNU Affero General Public License is designed specifically to
ensure that, in such cases, the modified source code becomes available
to the community. It requires the operator of a network server to
provide the source code of the modified version running there to the
users of that server. Therefore, public use of a modified version, on
a publicly accessible server, gives the public access to the source
code of the modified version.
An older license, called the Affero General Public License and
published by Affero, was designed to accomplish similar goals. This is
a different license, not a version of the Affero GPL, but Affero has
released a new version of the Affero GPL which permits relicensing under
this license.
The precise terms and conditions for copying, distribution and
modification follow.
TERMS AND CONDITIONS
0. Definitions.
"This License" refers to version 3 of the GNU Affero General Public License.
"Copyright" also means copyright-like laws that apply to other kinds of
works, such as semiconductor masks.
"The Program" refers to any copyrightable work licensed under this
License. Each licensee is addressed as "you". "Licensees" and
"recipients" may be individuals or organizations.
To "modify" a work means to copy from or adapt all or part of the work
in a fashion requiring copyright permission, other than the making of an
exact copy. The resulting work is called a "modified version" of the
earlier work or a work "based on" the earlier work.
A "covered work" means either the unmodified Program or a work based
on the Program.
To "propagate" a work means to do anything with it that, without
permission, would make you directly or secondarily liable for
infringement under applicable copyright law, except executing it on a
computer or modifying a private copy. Propagation includes copying,
distribution (with or without modification), making available to the
public, and in some countries other activities as well.
To "convey" a work means any kind of propagation that enables other
parties to make or receive copies. Mere interaction with a user through
a computer network, with no transfer of a copy, is not conveying.
An interactive user interface displays "Appropriate Legal Notices"
to the extent that it includes a convenient and prominently visible
feature that (1) displays an appropriate copyright notice, and (2)
tells the user that there is no warranty for the work (except to the
extent that warranties are provided), that licensees may convey the
work under this License, and how to view a copy of this License. If
the interface presents a list of user commands or options, such as a
menu, a prominent item in the list meets this criterion.
1. Source Code.
The "source code" for a work means the preferred form of the work
for making modifications to it. "Object code" means any non-source
form of a work.
A "Standard Interface" means an interface that either is an official
standard defined by a recognized standards body, or, in the case of
interfaces specified for a particular programming language, one that
is widely used among developers working in that language.
The "System Libraries" of an executable work include anything, other
than the work as a whole, that (a) is included in the normal form of
packaging a Major Component, but which is not part of that Major
Component, and (b) serves only to enable use of the work with that
Major Component, or to implement a Standard Interface for which an
implementation is available to the public in source code form. A
"Major Component", in this context, means a major essential component
(kernel, window system, and so on) of the specific operating system
(if any) on which the executable work runs, or a compiler used to
produce the work, or an object code interpreter used to run it.
The "Corresponding Source" for a work in object code form means all
the source code needed to generate, install, and (for an executable
work) run the object code and to modify the work, including scripts to
control those activities. However, it does not include the work's
System Libraries, or general-purpose tools or generally available free
programs which are used unmodified in performing those activities but
which are not part of the work. For example, Corresponding Source
includes interface definition files associated with source files for
the work, and the source code for shared libraries and dynamically
linked subprograms that the work is specifically designed to require,
such as by intimate data communication or control flow between those
subprograms and other parts of the work.
The Corresponding Source need not include anything that users
can regenerate automatically from other parts of the Corresponding
Source.
The Corresponding Source for a work in source code form is that
same work.
2. Basic Permissions.
All rights granted under this License are granted for the term of
copyright on the Program, and are irrevocable provided the stated
conditions are met. This License explicitly affirms your unlimited
permission to run the unmodified Program. The output from running a
covered work is covered by this License only if the output, given its
content, constitutes a covered work. This License acknowledges your
rights of fair use or other equivalent, as provided by copyright law.
You may make, run and propagate covered works that you do not
convey, without conditions so long as your license otherwise remains
in force. You may convey covered works to others for the sole purpose
of having them make modifications exclusively for you, or provide you
with facilities for running those works, provided that you comply with
the terms of this License in conveying all material for which you do
not control copyright. Those thus making or running the covered works
for you must do so exclusively on your behalf, under your direction
and control, on terms that prohibit them from making any copies of
your copyrighted material outside their relationship with you.
Conveying under any other circumstances is permitted solely under
the conditions stated below. Sublicensing is not allowed; section 10
makes it unnecessary.
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
No covered work shall be deemed part of an effective technological
measure under any applicable law fulfilling obligations under article
11 of the WIPO copyright treaty adopted on 20 December 1996, or
similar laws prohibiting or restricting circumvention of such
measures.
When you convey a covered work, you waive any legal power to forbid
circumvention of technological measures to the extent such circumvention
is effected by exercising rights under this License with respect to
the covered work, and you disclaim any intention to limit operation or
modification of the work as a means of enforcing, against the work's
users, your or third parties' legal rights to forbid circumvention of
technological measures.
4. Conveying Verbatim Copies.
You may convey verbatim copies of the Program's source code as you
receive it, in any medium, provided that you conspicuously and
appropriately publish on each copy an appropriate copyright notice;
keep intact all notices stating that this License and any
non-permissive terms added in accord with section 7 apply to the code;
keep intact all notices of the absence of any warranty; and give all
recipients a copy of this License along with the Program.
You may charge any price or no price for each copy that you convey,
and you may offer support or warranty protection for a fee.
5. Conveying Modified Source Versions.
You may convey a work based on the Program, or the modifications to
produce it from the Program, in the form of source code under the
terms of section 4, provided that you also meet all of these conditions:
a) The work must carry prominent notices stating that you modified
it, and giving a relevant date.
b) The work must carry prominent notices stating that it is
released under this License and any conditions added under section
7. This requirement modifies the requirement in section 4 to
"keep intact all notices".
c) You must license the entire work, as a whole, under this
License to anyone who comes into possession of a copy. This
License will therefore apply, along with any applicable section 7
additional terms, to the whole of the work, and all its parts,
regardless of how they are packaged. This License gives no
permission to license the work in any other way, but it does not
invalidate such permission if you have separately received it.
d) If the work has interactive user interfaces, each must display
Appropriate Legal Notices; however, if the Program has interactive
interfaces that do not display Appropriate Legal Notices, your
work need not make them do so.
A compilation of a covered work with other separate and independent
works, which are not by their nature extensions of the covered work,
and which are not combined with it such as to form a larger program,
in or on a volume of a storage or distribution medium, is called an
"aggregate" if the compilation and its resulting copyright are not
used to limit the access or legal rights of the compilation's users
beyond what the individual works permit. Inclusion of a covered work
in an aggregate does not cause this License to apply to the other
parts of the aggregate.
6. Conveying Non-Source Forms.
You may convey a covered work in object code form under the terms
of sections 4 and 5, provided that you also convey the
machine-readable Corresponding Source under the terms of this License,
in one of these ways:
a) Convey the object code in, or embodied in, a physical product
(including a physical distribution medium), accompanied by the
Corresponding Source fixed on a durable physical medium
customarily used for software interchange.
b) Convey the object code in, or embodied in, a physical product
(including a physical distribution medium), accompanied by a
written offer, valid for at least three years and valid for as
long as you offer spare parts or customer support for that product
model, to give anyone who possesses the object code either (1) a
copy of the Corresponding Source for all the software in the
product that is covered by this License, on a durable physical
medium customarily used for software interchange, for a price no
more than your reasonable cost of physically performing this
conveying of source, or (2) access to copy the
Corresponding Source from a network server at no charge.
c) Convey individual copies of the object code with a copy of the
written offer to provide the Corresponding Source. This
alternative is allowed only occasionally and noncommercially, and
only if you received the object code with such an offer, in accord
with subsection 6b.
d) Convey the object code by offering access from a designated
place (gratis or for a charge), and offer equivalent access to the
Corresponding Source in the same way through the same place at no
further charge. You need not require recipients to copy the
Corresponding Source along with the object code. If the place to
copy the object code is a network server, the Corresponding Source
may be on a different server (operated by you or a third party)
that supports equivalent copying facilities, provided you maintain
clear directions next to the object code saying where to find the
Corresponding Source. Regardless of what server hosts the
Corresponding Source, you remain obligated to ensure that it is
available for as long as needed to satisfy these requirements.
e) Convey the object code using peer-to-peer transmission, provided
you inform other peers where the object code and Corresponding
Source of the work are being offered to the general public at no
charge under subsection 6d.
A separable portion of the object code, whose source code is excluded
from the Corresponding Source as a System Library, need not be
included in conveying the object code work.
A "User Product" is either (1) a "consumer product", which means any
tangible personal property which is normally used for personal, family,
or household purposes, or (2) anything designed or sold for incorporation
into a dwelling. In determining whether a product is a consumer product,
doubtful cases shall be resolved in favor of coverage. For a particular
product received by a particular user, "normally used" refers to a
typical or common use of that class of product, regardless of the status
of the particular user or of the way in which the particular user
actually uses, or expects or is expected to use, the product. A product
is a consumer product regardless of whether the product has substantial
commercial, industrial or non-consumer uses, unless such uses represent
the only significant mode of use of the product.
"Installation Information" for a User Product means any methods,
procedures, authorization keys, or other information required to install
and execute modified versions of a covered work in that User Product from
a modified version of its Corresponding Source. The information must
suffice to ensure that the continued functioning of the modified object
code is in no case prevented or interfered with solely because
modification has been made.
If you convey an object code work under this section in, or with, or
specifically for use in, a User Product, and the conveying occurs as
part of a transaction in which the right of possession and use of the
User Product is transferred to the recipient in perpetuity or for a
fixed term (regardless of how the transaction is characterized), the
Corresponding Source conveyed under this section must be accompanied
by the Installation Information. But this requirement does not apply
if neither you nor any third party retains the ability to install
modified object code on the User Product (for example, the work has
been installed in ROM).
The requirement to provide Installation Information does not include a
requirement to continue to provide support service, warranty, or updates
for a work that has been modified or installed by the recipient, or for
the User Product in which it has been modified or installed. Access to a
network may be denied when the modification itself materially and
adversely affects the operation of the network or violates the rules and
protocols for communication across the network.
Corresponding Source conveyed, and Installation Information provided,
in accord with this section must be in a format that is publicly
documented (and with an implementation available to the public in
source code form), and must require no special password or key for
unpacking, reading or copying.
7. Additional Terms.
"Additional permissions" are terms that supplement the terms of this
License by making exceptions from one or more of its conditions.
Additional permissions that are applicable to the entire Program shall
be treated as though they were included in this License, to the extent
that they are valid under applicable law. If additional permissions
apply only to part of the Program, that part may be used separately
under those permissions, but the entire Program remains governed by
this License without regard to the additional permissions.
When you convey a copy of a covered work, you may at your option
remove any additional permissions from that copy, or from any part of
it. (Additional permissions may be written to require their own
removal in certain cases when you modify the work.) You may place
additional permissions on material, added by you to a covered work,
for which you have or can give appropriate copyright permission.
Notwithstanding any other provision of this License, for material you
add to a covered work, you may (if authorized by the copyright holders of
that material) supplement the terms of this License with terms:
a) Disclaiming warranty or limiting liability differently from the
terms of sections 15 and 16 of this License; or
b) Requiring preservation of specified reasonable legal notices or
author attributions in that material or in the Appropriate Legal
Notices displayed by works containing it; or
c) Prohibiting misrepresentation of the origin of that material, or
requiring that modified versions of such material be marked in
reasonable ways as different from the original version; or
d) Limiting the use for publicity purposes of names of licensors or
authors of the material; or
e) Declining to grant rights under trademark law for use of some
trade names, trademarks, or service marks; or
f) Requiring indemnification of licensors and authors of that
material by anyone who conveys the material (or modified versions of
it) with contractual assumptions of liability to the recipient, for
any liability that these contractual assumptions directly impose on
those licensors and authors.
All other non-permissive additional terms are considered "further
restrictions" within the meaning of section 10. If the Program as you
received it, or any part of it, contains a notice stating that it is
governed by this License along with a term that is a further
restriction, you may remove that term. If a license document contains
a further restriction but permits relicensing or conveying under this
License, you may add to a covered work material governed by the terms
of that license document, provided that the further restriction does
not survive such relicensing or conveying.
If you add terms to a covered work in accord with this section, you
must place, in the relevant source files, a statement of the
additional terms that apply to those files, or a notice indicating
where to find the applicable terms.
Additional terms, permissive or non-permissive, may be stated in the
form of a separately written license, or stated as exceptions;
the above requirements apply either way.
8. Termination.
You may not propagate or modify a covered work except as expressly
provided under this License. Any attempt otherwise to propagate or
modify it is void, and will automatically terminate your rights under
this License (including any patent licenses granted under the third
paragraph of section 11).
However, if you cease all violation of this License, then your
license from a particular copyright holder is reinstated (a)
provisionally, unless and until the copyright holder explicitly and
finally terminates your license, and (b) permanently, if the copyright
holder fails to notify you of the violation by some reasonable means
prior to 60 days after the cessation.
Moreover, your license from a particular copyright holder is
reinstated permanently if the copyright holder notifies you of the
violation by some reasonable means, this is the first time you have
received notice of violation of this License (for any work) from that
copyright holder, and you cure the violation prior to 30 days after
your receipt of the notice.
Termination of your rights under this section does not terminate the
licenses of parties who have received copies or rights from you under
this License. If your rights have been terminated and not permanently
reinstated, you do not qualify to receive new licenses for the same
material under section 10.
9. Acceptance Not Required for Having Copies.
You are not required to accept this License in order to receive or
run a copy of the Program. Ancillary propagation of a covered work
occurring solely as a consequence of using peer-to-peer transmission
to receive a copy likewise does not require acceptance. However,
nothing other than this License grants you permission to propagate or
modify any covered work. These actions infringe copyright if you do
not accept this License. Therefore, by modifying or propagating a
covered work, you indicate your acceptance of this License to do so.
10. Automatic Licensing of Downstream Recipients.
Each time you convey a covered work, the recipient automatically
receives a license from the original licensors, to run, modify and
propagate that work, subject to this License. You are not responsible
for enforcing compliance by third parties with this License.
An "entity transaction" is a transaction transferring control of an
organization, or substantially all assets of one, or subdividing an
organization, or merging organizations. If propagation of a covered
work results from an entity transaction, each party to that
transaction who receives a copy of the work also receives whatever
licenses to the work the party's predecessor in interest had or could
give under the previous paragraph, plus a right to possession of the
Corresponding Source of the work from the predecessor in interest, if
the predecessor has it or can get it with reasonable efforts.
You may not impose any further restrictions on the exercise of the
rights granted or affirmed under this License. For example, you may
not impose a license fee, royalty, or other charge for exercise of
rights granted under this License, and you may not initiate litigation
(including a cross-claim or counterclaim in a lawsuit) alleging that
any patent claim is infringed by making, using, selling, offering for
sale, or importing the Program or any portion of it.
11. Patents.
A "contributor" is a copyright holder who authorizes use under this
License of the Program or a work on which the Program is based. The
work thus licensed is called the contributor's "contributor version".
A contributor's "essential patent claims" are all patent claims
owned or controlled by the contributor, whether already acquired or
hereafter acquired, that would be infringed by some manner, permitted
by this License, of making, using, or selling its contributor version,
but do not include claims that would be infringed only as a
consequence of further modification of the contributor version. For
purposes of this definition, "control" includes the right to grant
patent sublicenses in a manner consistent with the requirements of
this License.
Each contributor grants you a non-exclusive, worldwide, royalty-free
patent license under the contributor's essential patent claims, to
make, use, sell, offer for sale, import and otherwise run, modify and
propagate the contents of its contributor version.
In the following three paragraphs, a "patent license" is any express
agreement or commitment, however denominated, not to enforce a patent
(such as an express permission to practice a patent or covenant not to
sue for patent infringement). To "grant" such a patent license to a
party means to make such an agreement or commitment not to enforce a
patent against the party.
If you convey a covered work, knowingly relying on a patent license,
and the Corresponding Source of the work is not available for anyone
to copy, free of charge and under the terms of this License, through a
publicly available network server or other readily accessible means,
then you must either (1) cause the Corresponding Source to be so
available, or (2) arrange to deprive yourself of the benefit of the
patent license for this particular work, or (3) arrange, in a manner
consistent with the requirements of this License, to extend the patent
license to downstream recipients. "Knowingly relying" means you have
actual knowledge that, but for the patent license, your conveying the
covered work in a country, or your recipient's use of the covered work
in a country, would infringe one or more identifiable patents in that
country that you have reason to believe are valid.
If, pursuant to or in connection with a single transaction or
arrangement, you convey, or propagate by procuring conveyance of, a
covered work, and grant a patent license to some of the parties
receiving the covered work authorizing them to use, propagate, modify
or convey a specific copy of the covered work, then the patent license
you grant is automatically extended to all recipients of the covered
work and works based on it.
A patent license is "discriminatory" if it does not include within
the scope of its coverage, prohibits the exercise of, or is
conditioned on the non-exercise of one or more of the rights that are
specifically granted under this License. You may not convey a covered
work if you are a party to an arrangement with a third party that is
in the business of distributing software, under which you make payment
to the third party based on the extent of your activity of conveying
the work, and under which the third party grants, to any of the
parties who would receive the covered work from you, a discriminatory
patent license (a) in connection with copies of the covered work
conveyed by you (or copies made from those copies), or (b) primarily
for and in connection with specific products or compilations that
contain the covered work, unless you entered into that arrangement,
or that patent license was granted, prior to 28 March 2007.
Nothing in this License shall be construed as excluding or limiting
any implied license or other defenses to infringement that may
otherwise be available to you under applicable patent law.
12. No Surrender of Others' Freedom.
If conditions are imposed on you (whether by court order, agreement or
otherwise) that contradict the conditions of this License, they do not
excuse you from the conditions of this License. If you cannot convey a
covered work so as to satisfy simultaneously your obligations under this
License and any other pertinent obligations, then as a consequence you may
not convey it at all. For example, if you agree to terms that obligate you
to collect a royalty for further conveying from those to whom you convey
the Program, the only way you could satisfy both those terms and this
License would be to refrain entirely from conveying the Program.
13. Remote Network Interaction; Use with the GNU General Public License.
Notwithstanding any other provision of this License, if you modify the
Program, your modified version must prominently offer all users
interacting with it remotely through a computer network (if your version
supports such interaction) an opportunity to receive the Corresponding
Source of your version by providing access to the Corresponding Source
from a network server at no charge, through some standard or customary
means of facilitating copying of software. This Corresponding Source
shall include the Corresponding Source for any work covered by version 3
of the GNU General Public License that is incorporated pursuant to the
following paragraph.
Notwithstanding any other provision of this License, you have
permission to link or combine any covered work with a work licensed
under version 3 of the GNU General Public License into a single
combined work, and to convey the resulting work. The terms of this
License will continue to apply to the part which is the covered work,
but the work with which it is combined will remain governed by version
3 of the GNU General Public License.
14. Revised Versions of this License.
The Free Software Foundation may publish revised and/or new versions of
the GNU Affero General Public License from time to time. Such new versions
will be similar in spirit to the present version, but may differ in detail to
address new problems or concerns.
Each version is given a distinguishing version number. If the
Program specifies that a certain numbered version of the GNU Affero General
Public License "or any later version" applies to it, you have the
option of following the terms and conditions either of that numbered
version or of any later version published by the Free Software
Foundation. If the Program does not specify a version number of the
GNU Affero General Public License, you may choose any version ever published
by the Free Software Foundation.
If the Program specifies that a proxy can decide which future
versions of the GNU Affero General Public License can be used, that proxy's
public statement of acceptance of a version permanently authorizes you
to choose that version for the Program.
Later license versions may give you additional or different
permissions. However, no additional obligations are imposed on any
author or copyright holder as a result of your choosing to follow a
later version.
15. Disclaimer of Warranty.
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
16. Limitation of Liability.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGES.
17. Interpretation of Sections 15 and 16.
If the disclaimer of warranty and limitation of liability provided
above cannot be given local legal effect according to their terms,
reviewing courts shall apply local law that most closely approximates
an absolute waiver of all civil liability in connection with the
Program, unless a warranty or assumption of liability accompanies a
copy of the Program in return for a fee.
END OF TERMS AND CONDITIONS
How to Apply These Terms to Your New Programs
If you develop a new program, and you want it to be of the greatest
possible use to the public, the best way to achieve this is to make it
free software which everyone can redistribute and change under these terms.
To do so, attach the following notices to the program. It is safest
to attach them to the start of each source file to most effectively
state the exclusion of warranty; and each file should have at least
the "copyright" line and a pointer to where the full notice is found.
<one line to give the program's name and a brief idea of what it does.>
Copyright (C) <year> <name of author>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
Also add information on how to contact you by electronic and paper mail.
If your software can interact with users remotely through a computer
network, you should also make sure that it provides a way for users to
get its source. For example, if your program is a web application, its
interface could display a "Source" link that leads users to an archive
of the code. There are many ways you could offer source, and different
solutions will be better for different programs; see section 13 for the
specific requirements.
You should also get your employer (if you work as a programmer) or school,
if any, to sign a "copyright disclaimer" for the program, if necessary.
For more information on this, and how to apply and follow the GNU AGPL, see
<https://www.gnu.org/licenses/>.

View File

@ -1,24 +1,21 @@
include pandoc-man.mk
ifeq ($(PREFIX),)
PREFIX := /usr
PREFIX := /usr/local
endif
datarootdir := $(PREFIX)/share
datadir := $(datarootdir)
mandir := $(datarootdir)/man
bindir := $(PREFIX)/bin
configdir := $(datarootdir)/distrohopper
ICONS_DIR := config/icons
all: distrohopper.1 quickget.1 quickemu.1 quickemu_conf.1
all: quickget.1 quickemu.1 quickemu_conf.1
clean:
rm *.1
install_docs: all
install -d $(DESTDIR)$(mandir)/man1
install -m 644 distrohopper.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickget.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickemu.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickemu_conf.1 $(DESTDIR)$(mandir)/man1
@ -27,38 +24,19 @@ install_docs: all
install_bins:
install -d $(DESTDIR)$(bindir)
install -m 755 ../dh $(DESTDIR)$(bindir)
install -m 755 ../quickget $(DESTDIR)$(bindir)
install -m 755 ../quickemu $(DESTDIR)$(bindir)
install -m 755 ../macrecovery $(DESTDIR)$(bindir)
install_config:
install: install_bins install_docs
install_icons:
install -d $(DESTDIR)$(datadir)/icons/distrohopper
install -m 644 $(ICONS_DIR)/*.svg $(DESTDIR)$(datadir)/icons/distrohopper
install -m 644 $(ICONS_DIR)/*.png $(DESTDIR)$(datadir)/icons/distrohopper
install: install_bins install_docs install_icons
uninstall_icons:
rm -f $(DESTDIR)$(datadir)/icons/distrohopper/*.svg
rm -f $(DESTDIR)$(datadir)/icons/distrohopper/*.png
uninstall_docs:
rm -f $(DESTDIR)$(mandir)/man1/distrohopper.1
uninstall::
rm -f $(DESTDIR)$(mandir)/man1/quickget.1
rm -f $(DESTDIR)$(mandir)/man1/quickemu.1
rm -f $(DESTDIR)$(mandir)/man1/quickemu_conf.1
uninstall_bins:
rm -f $(DESTDIR)$(bindir)/dh
rm -f $(DESTDIR)$(bindir)/quickget
rm -f $(DESTDIR)$(bindir)/quickemu
rm -f $(DESTDIR)$(bindir)/macrecovery
uninstall: uninstall_icons uninstall_docs uninstall_bins
.PHONY: all

299
docs/README.md Normal file
View File

@ -0,0 +1,299 @@
![](https://img.shields.io/github/stars/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=instatus&logoColor=000000)
![](https://img.shields.io/github/forks/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=git&logoColor=000000)
![](https://img.shields.io/github/license/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=apache&logoColor=000000)
![](https://img.shields.io/github/repo-size/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=files&logoColor=000000)
![](https://img.shields.io/github/last-commit/oSoWoSo/DistroHopper?style=for-the-badge&color=8BC53F&logo=codeigniter&logoColor=000000)
![](https://img.shields.io/badge/language-shell-green?style=for-the-badge&color=8BC53F&logo=sharp&logoColor=000000)
![](https://img.shields.io/badge/gitmoji-%20😜%20😍-FFDD67.svg?style=for-the-badge&color=8BC53F&logo=sharp&logoColor=000000&alt="Gitmoji")
---
# Looking to try out a new operating system?
try
# **DistroHopper**
Quickly download, create and run VM of any#TODO operating system.
Linux![Tux](tux23.png) required...
---
Click on Hop for latest download
[![Hop](hop120.png)](https://sourceforge.net/projects/distrohopper/files/latest/download)
[![Donate](https://liberapay.com/assets/widgets/donate.svg)](https://liberapay.com/zenobit/donate)
Licensed under AGPL3
# Still Beta version!
<details>
<summary>Click for screenshot</summary>
![supported Operating systems](distrohopper.png)
</details>
As a base excellent [quickemu](https://github.com/quickemu-project/quickemu) (Link to project page)
<details>
<summary>Click for Quickemu old video</summary>
<iframe width="960" height="540" src="https://www.youtube-nocookie.com/embed/AOTYWEgw0hI" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>
</details>
You can download new distro with **few clicks** of a mouse
# Features
- GUI using yad
<details>
<summary>Click for old video</summary>
<iframe width="960" height="540" src="https://www.youtube-nocookie.com/embed/RrFQECcwLRA" title="DistroHopper" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>
</details>
- TUI using fzf
<details>
<summary>Click for old video</summary>
<iframe width="960" height="540" src="https://www.youtube-nocookie.com/embed/gJ5hqYEskOw" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>
</details>
- Desktop(shortcuts) entries generator
- Set dir where VMs will be stored
- Install DistroHopper systemwide
- Portable mode (dependecies still must be installed)
- Add new operating system to quickget (bit easier)
- Copy all downloaded ISOs to destination directory
- Translate DistroHopper (Currently supported English and Czech language)
Developed in English and translated into Czech language.
## Welcome translations!
---
# Why am I doing it?
Because I wanna learn
- Linux
- Bash
- yad
- project management
And contribute to open source
play with Quickemu
And easily add new distros to it
---
## How to run DistroHopper?
You need fullfill the requirement first...
## Requirements (For running VMs)
- [QEMU](https://www.qemu.org/) (*6.0.0 or newer*) **with GTK, SDL, SPICE & VirtFS support**
- [bash](https://www.gnu.org/software/bash/) (*4.0 or newer*)
- [Coreutils](https://www.gnu.org/software/coreutils/)
- [EDK II](https://github.com/tianocore/edk2)
- [grep](https://www.gnu.org/software/grep/)
- [jq](https://stedolan.github.io/jq/)
- [LSB](https://wiki.linuxfoundation.org/lsb/start)
- [procps](https://gitlab.com/procps-ng/procps)
- [python3](https://www.python.org/)
- [macrecovery](https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macrecovery)
- [mkisofs](http://cdrtools.sourceforge.net/private/cdrecord.html)
- [usbutils](https://github.com/gregkh/usbutils)
- [util-linux](https://github.com/karelzak/util-linux)
- [sed](https://www.gnu.org/software/sed/)
- [socat](http://www.dest-unreach.org/socat/)
- [spicy](https://gitlab.freedesktop.org/spice/spice-gtk)
- [swtpm](https://github.com/stefanberger/swtpm)
- [Wget](https://www.gnu.org/software/wget/)
- [xdg-user-dirs](https://www.freedesktop.org/wiki/Software/xdg-user-dirs/)
- [xrandr](https://gitlab.freedesktop.org/xorg/app/xrandr)
- [zsync](http://zsync.moria.org.uk/)
- [unzip](http://www.info-zip.org/UnZip.html)
### Installing Requirements
For Ubuntu, Arch and nixos systems the
[ppa](https://launchpad.net/~flexiondotorg/+archive/ubuntu/quickemu),
[AUR](https://aur.archlinux.org/packages/quickemu) or
[nix](https://github.com/NixOS/nixpkgs/tree/master/pkgs/development/quickemu)
packaging will take care of the dependencies. For other host
distributions or operating systems it will be necessary to install the
above requirements or their equivalents.
If you install DistroHopper, it should take care of dependencies on Arch, Debian, Ubuntu, openSuse and Fedora
### For DistroHopper to work you need
`wget yad fzf`
quickemu is included
For adding new distros, or adding/improving translations you will need also meld.
# How to install DistroHopper?
You need get copy of distrohopper
If you want more stable experience, download latest release from
#### [GitHub](https://github.com/oSoWoSo/DistroHopper/releases) or SourceForge [![SourceForge](https://img.shields.io/sourceforge/dt/distrohopper.svg)](https://sourceforge.net/projects/distrohopper/files/latest/download)
---
If you want latest developer version... (could have bugs and break anytime)
Or you want translate DistroHopper
`git clone https://github.com/oSoWoSo/DistroHopper`
Enter created/unpacked distrohopper directory
Now you should be good to go...
---
# How to run DistroHopper
Just run from terminal
`./dh`
And you will see what next...
I am usually run DistroHopper as:
`./dh m r s l && ./dh i && dh g`
(But...)
## Desktop files
All desktop files will be storred in your .config/distrohopper
in directories *ready* and *supported*
Fell free to copy them anywhere you want...
### Currently supported Operating Systems and tools:
- agarimos - alma - alpine - android - archlinux - archcraft - arcolinux
- batocera - blendos - cachyos - centos-stream - cereus - debian - deepin
- devuan - dietpi - dragonflybsd - elementary - endeavouros - endless
- fedora - freebsd - freedos - fvoid - gabeeos - garuda - gentoo
- ghostbsd - haiku - kali - kdeneon - kolibrios - kubuntu - linuxmint
- lmde - mageia - manjaro - miyo - mxlinux - netboot - netbsd - nixos
- lubuntu - macos - openbsd - opensuse - oraclelinux - popos - reactos
- rebornos - rockylinux - siduction - slackware - slitaz - solus
- steamos - tails - truenas-core - truenas-scale - ubuntu - ubuntu-budgie
- ubuntukylin - ubuntu-mate - ubuntustudio - ubuntu-unity - ventoy - void
- voidpup - vxlinux - windows - xerolinux - xubuntu - zorin
Also with posible planned: [in discusion](https://github.com/oSoWoSo/DistroHopper/discussions/9)
---
#### [discuss](https://github.com/oSoWoSo/DistroHopper/discussions) on github
# Join DistroHopper chat group:
[![SimpleX](simplex.svg)](https://simplex.chat/contact#/?v=1-2&smp=smp%3A%2F%2FSkIkI6EPd2D63F4xFKfHk7I1UGZVNn6k1QWZ5rcyr6w%3D%40smp9.simplex.im%2FzmtsZwfTjwyynibt0bF6bb_xLWS9ce5A%23%2F%3Fv%3D1-2%26dh%3DMCowBQYDK2VuAyEAkMtz66wGfWb6VDn-_t_mVm3RFiFfOC3Hxye8Hm5tmVo%253D%26srv%3Djssqzccmrcws6bhmn77vgmhfjmhwlyr3u7puw4erkyoosywgl67slqqd.onion&data=%7B%22type%22%3A%22group%22%2C%22groupLinkId%22%3A%22o8KR0TOM0f2j33nO9goMRQ%3D%3D%22%7D) (click SimpleX logo)
(check the software! even if you don't want chat about DistroHopper)
[Simplex website](https://simplex.chat)
# Without these amazing projects it wouldn't be posible:
#### [bash](https://www.gnu.org/software/bash/)
#### [QEMU](https://www.qemu.org/)
#### [quickemu](https://github.com/quickemu-project/quickemu)
GUI depends on
#### [yad](https://github.com/v1cont/yad)
TUI depends on
#### [fzf](https://github.com/junegunn/fzf)
----
For
- easy of use
#### [fish](https://fishshell.com)
- commiting and working with github
#### [lazygit](https://github.com/jesseduffield/lazygit)
#### [opencommit](https://github.com/di-sukharev/opencommit)
- Editing
#### [geany](https://geany.org/)
#### [Kate](https://apps.kde.org/kate)
- diff
#### [Meld](https://meld.app/)
- Logo and icons
#### [GIMP](https://www.gimp.org)
and
#### [Inkscape](https://inkscape.org)
#### [logo by](https://freesvg.org/by/OpenClipart) bit repaired by me..
- Updating translation
#### [Poedit](https://poeditor.com/)
Everything done on
#### [Void Linux](https://voidlinux.org)
---
# Mirrored on
#### [GitHub](https://github.com/oSoWoSo/DistroHopper)
#### [SourceForge](https://sourceforge.net/projects/distrohopper)
#### [Disroot](https://git.disroot.org/oSoWoSo/DistroHopper)
#### [Codeberg](https://codeberg.org/oSoWoSo/DistroHopper)
#### [GitLab](https://gitlab.com/osowoso/distrohopper)
#### [SourceHut](https://git.sr.ht/~osowoso/DistroHopper)
---
For Homepage click on Hop
[![Hop](hop120.png)](https://dh.osowoso.xyz/)
# donate
[![Donate](https://liberapay.com/assets/widgets/donate.svg)](https://liberapay.com/zenobit/donate)
@zen0bit at github
mailto: <zenobit@osowoso.xyz>
[up](./)
#### parent site [oSoWoSo](https://osowoso.xyz)

View File

@ -7,13 +7,13 @@ buttons:
remote_theme: oSoWoSo/cayman-vb-dark
# web title
title: oSoWoSo
title: DistroHopper
# web desription
description: DistroHopper
description: Quickly download, create and run VM of any#TODO operating system
# Header buttons for downloads from github repo
#show_downloads: true
show_downloads: true
# Header buttons link to github repo
show_github: true
@ -22,7 +22,7 @@ show_github: true
#google_analytics:
# web PNG favicon
favicon: assets/img/osowoso.png
favicon: logo.svg
# Icon shown in header. From Fontawesome https://fontawesome.com/icons?m=free
#icon: fas fa-pencil-alt

BIN
docs/distrohopper.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 203 KiB

BIN
docs/favicon.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

298
docs/hop-big.svg Normal file
View File

@ -0,0 +1,298 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->
<svg
width="560"
height="560"
viewBox="0 0 560 560"
version="1.1"
id="SVGRoot"
sodipodi:docname="hopB.svg"
inkscape:version="1.1.1 (3bf5ae0d25, 2021-09-20)"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns="http://www.w3.org/2000/svg"
xmlns:svg="http://www.w3.org/2000/svg">
<sodipodi:namedview
id="namedview460"
pagecolor="#505050"
bordercolor="#eeeeee"
borderopacity="1"
inkscape:pageshadow="0"
inkscape:pageopacity="0"
inkscape:pagecheckerboard="0"
inkscape:document-units="px"
showgrid="true"
inkscape:zoom="0.27496365"
inkscape:cx="-158.20273"
inkscape:cy="1214.706"
inkscape:window-width="3440"
inkscape:window-height="1440"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="1"
inkscape:current-layer="layer1">
<inkscape:grid
type="xygrid"
id="grid466" />
</sodipodi:namedview>
<defs
id="defs455" />
<g
inkscape:label="Vrstva 1"
inkscape:groupmode="layer"
id="layer1">
<g
id="g236"
transform="matrix(1.4002461,0,0,1.4002461,24.902044,64.835941)">
<g
id="g238">
<g
id="g240">
<path
id="path242"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 1.5,236.16 c -0.004,-12.97 10.514,-23.49 23.49,-23.5 12.977,0 23.496,10.53 23.493,23.5 z" />
<g
id="g244">
<path
id="path246"
style="fill:#8bc53f"
d="m 32.152,229.69 c 0,0 19.769,-113.59 23.814,-137.78 3.201,-19.139 15.393,-18.975 22.186,-13.222 17.223,14.586 51.998,61.002 51.998,61.002 l 18,-14 c 0,0 -55.121634,-49.760407 -71.080634,-65.720407 C 67.466366,50.366593 51.322,58.771 44.966,77.914 37.237,101.19 16.152,215.694 16.152,215.694 l 16,14 z"
sodipodi:nodetypes="cccccccccc" />
<g
id="g248">
<path
id="path250"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 14.152,220.69 c 0,0 24.769,-112.59 28.814,-136.78 3.201,-19.139 19.686,-38.722 36.186,-22.222 15.959,15.959 68.998,64.002 68.998,64.002" />
<path
id="path252"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="M 34.152,219.69 C 49.121,121.36 50.043,126.36 54.966,96.91 58.932,73.2 68.554,70.091 83.152,84.688 99.111,100.65 131.15,139.69 131.15,139.69" />
</g>
</g>
</g>
<g
id="g254">
<path
id="path256"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 364.15,236.16 c 0.01,-12.97 -10.51,-23.49 -23.49,-23.5 -12.98,0 -23.49,10.53 -23.49,23.5 z" />
<g
id="g258">
<path
id="path260"
style="fill:#8bc53f"
d="m 333.5,229.69 c 0,0 -19.77,-113.59 -23.81,-137.78 -3.21,-19.139 -15.4,-18.975 -22.19,-13.222 -17.22,14.586 -52,61.002 -52,61.002 l -18,-14 c 0,0 55.41772,-51.621245 71.37772,-67.581245 9.6,-9.603 25.45228,0.662245 31.81228,19.805245 7.73,23.276 28.81,137.78 28.81,137.78 l -16,14 z"
sodipodi:nodetypes="cccccccccc" />
<g
id="g262">
<path
id="path264"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 351.5,220.69 c 0,0 -24.77,-112.59 -28.81,-136.78 C 319.48,64.771 303,45.188 286.5,61.688 c -15.96,15.959 -69,64.002 -69,64.002" />
<path
id="path266"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="M 331.5,219.69 C 316.53,121.36 315.61,126.36 310.69,96.91 306.72,73.2 297.1,70.091 282.5,84.688 c -15.96,15.962 -48,55.002 -48,55.002" />
</g>
</g>
</g>
</g>
<g
id="g268">
<g
id="g270">
<path
id="path272"
style="fill:#f7a03a;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 105.9,190.62 c -0.01,42.44 34.39,76.86 76.83,76.86 42.45,0 76.85,-34.41 76.85,-76.86 z" />
<path
id="path274"
style="fill:#d37d1a;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 105.9,190.62 c -0.01,25.67 34.39,63.07 76.83,63.07 42.45,0 76.85,-37.4 76.85,-63.07 z" />
<path
id="path276"
style="display:none;fill:#b06815;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 105.9,190.62 c -0.01,17.88 34.39,48.97 76.83,48.97 42.45,0 76.85,-31.08 76.85,-48.97 z" />
</g>
<g
id="g278">
<path
id="path280"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 182.94,113.83 c -42.56,0 -77.05,34.57 -77.04,77.19 h 77.04 z" />
<path
id="path282"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 259.75,191.02 c 0.01,-42.63 -34.48,-77.19 -77.03,-77.19 v 77.19 z" />
</g>
</g>
<g
id="g284">
<g
id="g286">
<path
id="path288"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 36.584,267.68 c -0.004,-12.97 10.515,-23.5 23.49,-23.5 12.978,0 23.496,10.52 23.493,23.5 z" />
<g
id="g290">
<path
id="path292"
style="fill:#8bc53f"
d="M 71.655,251.69 71.47,147.91 c 2.303,-27.62 7.436,-35.72 25.186,-19.22 16.534,15.36 23.004,32 23.004,32 l 2,-23 c 0,0 -11.47,-9.64 -28.004,-25 -17.75,-16.503 -29.883,-7.4 -32.186,20.22 l -7.814,115.78 z" />
<g
id="g294">
<path
id="path296"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 53.655,249.69 7.814,-116.78 c 2.303,-27.62 14.436,-36.722 32.186,-20.22 16.535,15.36 28.005,25 28.005,25" />
<path
id="path298"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="M 71.655,251.69 71.47,147.91 c 2.303,-27.62 7.436,-35.72 25.186,-19.22 16.534,15.36 22.004,34 22.004,34" />
</g>
</g>
</g>
<g
id="g300">
<path
id="path302"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 329.07,267.68 c 0,-12.97 -10.52,-23.5 -23.49,-23.5 -12.98,0 -23.5,10.52 -23.5,23.5 z" />
<g
id="g304">
<path
id="path306"
style="fill:#8bc53f"
d="m 294,251.69 0.18,-103.78 c -2.3,-27.62 -7.43,-35.72 -25.18,-19.22 -16.53,15.36 -23,32 -23,32 l -2,-23 c 0,0 11.47,-9.64 28,-25 17.75,-16.502 29.88,-7.4 32.18,20.22 L 312,248.69 Z" />
<g
id="g308">
<path
id="path310"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 312,249.69 -7.82,-116.78 c -2.3,-27.62 -14.43,-36.722 -32.18,-20.22 -16.53,15.36 -28,25 -28,25" />
<path
id="path312"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 294,251.69 0.18,-103.78 c -2.3,-27.62 -7.43,-35.72 -25.18,-19.22 -16.53,15.36 -22,34 -22,34" />
</g>
</g>
</g>
</g>
<g
id="g314">
<path
id="path2383"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 240.49,185.01 c 0.01,31.85 -25.81,57.68 -57.67,57.68 -31.85,0 -57.67,-25.83 -57.66,-57.69 -0.01,-31.85 25.82,-57.68 57.67,-57.68 31.85,0.01 57.67,25.84 57.66,57.69 z" />
<g
id="g317">
<g
id="g319">
<g
id="g321">
<path
id="path323"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 171.09,141.5 c 0,0 14,-135.5 -110.5,-135.5" />
<circle
id="circle325"
cy="6"
cx="60.591"
r="6" />
</g>
<g
id="g327">
<path
id="path329"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 194.56,143.69 c 0,0 -14,-135.5 110.5,-135.5" />
<circle
id="circle331"
cy="8.1870003"
cx="305.06"
r="6" />
</g>
</g>
<path
id="path333"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 145.2,193.86 c -0.01,20.78 16.84,37.63 37.62,37.63 20.79,0.01 37.64,-16.85 37.63,-37.63" />
<g
id="g335">
<g
id="g337">
<path
id="path3159_1_"
style="fill:#ffffff;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 246.72,146.52 c 0.01,16.48 -13.35,29.85 -29.84,29.85 -16.49,0 -29.85,-13.37 -29.84,-29.85 -0.01,-16.49 13.36,-29.85 29.84,-29.85 16.49,0 29.85,13.37 29.84,29.85 z" />
<path
id="path3161_1_"
d="m 220.2,151.79 c 0,5.49 -4.46,9.95 -9.95,9.95 -5.49,0 -9.95,-4.46 -9.95,-9.95 0,-5.5 4.46,-9.95 9.95,-9.95 5.5,0 9.95,4.45 9.95,9.95 z" />
</g>
<g
id="g341">
<path
id="path3157_1_"
style="fill:#ffffff;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 178.61,146.52 c 0.01,16.48 -13.35,29.85 -29.84,29.85 -16.49,0 -29.85,-13.37 -29.84,-29.86 -0.01,-16.48 13.36,-29.85 29.84,-29.85 16.49,0 29.85,13.37 29.84,29.86 z" />
<path
id="path3163_1_"
d="m 166.18,151.78 c 0,5.5 -4.45,9.95 -9.95,9.95 -5.49,0 -9.95,-4.45 -9.94,-9.95 -0.01,-5.49 4.45,-9.95 9.94,-9.95 5.5,0 9.95,4.46 9.95,9.95 z" />
</g>
</g>
</g>
</g>
<g
id="g345">
<g
id="g347">
<path
id="path349"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 89.5,297.41 c -0.004,-12.97 10.51,-23.49 23.49,-23.49 12.98,0 23.5,10.52 23.49,23.49 z" />
<path
id="path351"
style="fill:#8bc53f"
d="m 119.35,279.79 -18.07,-75.07 c -10.25,-39.95 -1.19,-48.26 12.07,-21.93 l 4,-13 C 98.655,138.15 76.405,141.1 82.276,168.72 l 22.074,115.07 z" />
<g
id="g353">
<path
id="path355"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="M 104.35,283.79 82.276,168.72 c -5.395,-25.38 11.307,-32.32 31.794,-5.6 5.96,7.78 10.96,7.65 10.96,7.65" />
<path
id="path357"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 119.35,279.79 -18.07,-75.07 c -9.672,-36.09 -4.625,-46.53 8.68,-25.25 1.47,2.35 1.2,7.68 1.2,7.68" />
</g>
</g>
<g
id="g359">
<path
id="path361"
style="fill:#8bc53f;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 276.15,297.41 c 0.01,-12.97 -10.51,-23.49 -23.49,-23.49 -12.98,0 -23.49,10.52 -23.49,23.49 z" />
<path
id="path363"
style="fill:#8bc53f"
d="m 246.3,279.79 18.08,-75.07 c 10.24,-39.95 1.18,-48.26 -12.08,-21.93 l -4,-13 c 18.7,-31.64 40.95,-28.69 35.08,-1.07 L 261.3,283.79 Z" />
<g
id="g365">
<path
id="path367"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 261.3,283.79 22.08,-115.07 c 5.39,-25.38 -11.31,-32.32 -31.8,-5.6 -5.96,7.78 -10.96,7.65 -10.96,7.65" />
<path
id="path369"
style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round"
d="m 246.3,279.79 18.08,-75.07 c 9.66,-36.09 4.62,-46.53 -8.69,-25.25 -1.47,2.35 -1.19,7.68 -1.19,7.68" />
</g>
</g>
</g>
</g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 13 KiB

BIN
docs/hop120.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
docs/hop18.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 977 B

BIN
docs/hop20.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
docs/hop220.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

BIN
docs/hop320.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

BIN
docs/hop420.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

BIN
docs/hop48.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.9 KiB

BIN
docs/hop520.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 65 KiB

BIN
docs/hop60.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.4 KiB

View File

Before

Width:  |  Height:  |  Size: 12 KiB

After

Width:  |  Height:  |  Size: 12 KiB

View File

@ -1,4 +1,4 @@
.\" Automatically generated by Pandoc 2.19.2
.\" Automatically generated by Pandoc 2.17.1.1
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
@ -14,7 +14,7 @@
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKEMU" "1" "February 4, 2023" "quickemu" "Quickemu User Manual"
.TH "QUICKEMU" "1" "November 17, 2023" "quickemu" "Quickemu User Manual"
.hy
.SH NAME
.PP
@ -37,12 +37,17 @@ You can also pass optional parameters
Enable braille support.
Requires SDL.
.TP
\f[B]\[en]delete\f[R]
\f[B]\[en]delete-disk\f[R]
Delete the disk image.
.TP
\f[B]\[en]display\f[R]
Select display backend.
`sdl' (default), `gtk', `none' or `spice'
`sdl' (default), `gtk', `none', `spice' or `spice-app'
.TP
\f[B]\[en]sound-card\f[R]
Select virtual audio emulation.
`intel-hda' (default), `ac97' (solaris default), `es1370', `sb16'
(freedos default) or `none'
.TP
\f[B]\[en]fullscreen\f[R]
Starts VM in full screen mode (Ctl+Alt+f to exit)
@ -102,7 +107,7 @@ Windows\f[R].
.IP \[bu] 2
\f[B]macOS\f[R] Monterey, Big Sur, Catalina, Mojave & High Sierra
.IP \[bu] 2
\f[B]Windows\f[R] 8.1, 10 and 11 including TPM 2.0
\f[B]Windows\f[R] 10 and 11 including TPM 2.0
.IP \[bu] 2
Ubuntu (https://ubuntu.com/desktop) and all the \f[B]official Ubuntu
flavours (https://ubuntu.com/download/flavours)\f[R]
@ -209,11 +214,11 @@ to install the above requirements or their equivalents.
.PP
These examples may save a little typing
.PP
Debian:
Debian (and direct derivatives such as MX Linux):
.IP
.nf
\f[C]
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip
sudo apt install qemu bash coreutils ovmf grep jq lsb-base procps python3 genisoimage usbutils util-linux sed spice-client-gtk libtss2-tcti-swtpm0 wget xdg-user-dirs zsync unzip
\f[R]
.fi
.PP
@ -310,12 +315,16 @@ switch to a new series.
All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu\f[R] with your preferred flavour.
.IP \[bu] 2
\f[V]edubuntu\f[R] (Edubuntu)
.IP \[bu] 2
\f[V]kubuntu\f[R] (Kubuntu)
.IP \[bu] 2
\f[V]lubuntu\f[R] (Lubuntu)
.IP \[bu] 2
\f[V]ubuntu-budgie\f[R] (Ubuntu Budgie)
.IP \[bu] 2
\f[V]ubuntucinnamon\f[R] (Ubuntu Cinnamon)
.IP \[bu] 2
\f[V]ubuntukylin\f[R] (Ubuntu Kylin)
.IP \[bu] 2
\f[V]ubuntu-mate\f[R] (Ubuntu MATE)
@ -327,46 +336,93 @@ All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu-unity\f[R] (Ubuntu Unity)
.IP \[bu] 2
\f[V]xubuntu\f[R] (Xubuntu)
.PP
You can also use \f[V]quickget\f[R] with options to:
.IP
.nf
\f[C]
# show an OS ISO download URL for {os} {release} [edition]
quickget --show-iso-url fedora 38 Silverblue
# test if and OS ISO is available for {os} {release} [edition]
quickget --test-iso-url nixos 23.05 plasma5
# open an OS distribution homepage in a browser
quickget --open-distro-homepage ubuntu-mate
\f[R]
.fi
.PP
The \f[V]--show-iso-url\f[R] and \f[V]--test-iso-url\f[R] options
\f[B]do not\f[R] work for \f[V]Windows\f[R] (\f[V]quickget\f[R] will
begin downloading the requested release and edition of windows)
.SS Other Operating Systems
.PP
\f[V]quickget\f[R] also supports:
.IP \[bu] 2
\f[V]agarimos\f[R] (AgarimOS)
.IP \[bu] 2
\f[V]alma\f[R] (Alma Linux)
.IP \[bu] 2
\f[V]alpine\f[R] (Alpine Linux)
.IP \[bu] 2
\f[V]android\f[R] (Android x86)
.IP \[bu] 2
\f[V]antix\f[R] (Antix)
.IP \[bu] 2
\f[V]archcraft\f[R] (Archcraft)
.IP \[bu] 2
\f[V]archlinux\f[R] (Arch Linux)
.IP \[bu] 2
\f[V]arcolinux\f[R] (Arco Linux)
.IP \[bu] 2
\f[V]artixlinux\f[R] (Artix Linux)
.IP \[bu] 2
\f[V]athenaos\f[R] (Athenaos)
.IP \[bu] 2
\f[V]batocera\f[R] (Batocera)
.IP \[bu] 2
\f[V]bazzite\f[R] (Bazzite)
.IP \[bu] 2
\f[V]biglinux\f[R] (BigLinux)
.IP \[bu] 2
\f[V]blendos\f[R] (BlendOS)
.IP \[bu] 2
\f[V]bodhi\f[R] (Bodhi Linux)
.IP \[bu] 2
\f[V]bunsenlabs\f[R] (Bunsenlabs)
.IP \[bu] 2
\f[V]cachyos\f[R] (CachyOS)
.IP \[bu] 2
\f[V]centos-stream\f[R] (CentOS Stream)
.IP \[bu] 2
\f[V]cereus\f[R] (Cereus Linux)
.IP \[bu] 2
\f[V]chimera\f[R] (Chimera Linux)
.IP \[bu] 2
\f[V]debian\f[R] (Debian)
.IP \[bu] 2
\f[V]deepin\f[R] (Deepin)
.IP \[bu] 2
\f[V]devuan\f[R] (Devuan)
.IP \[bu] 2
\f[V]dietpi\f[R] (DietPi)
.IP \[bu] 2
\f[V]dragonflybsd\f[R] (DragonFlyBSD)
.IP \[bu] 2
\f[V]elementary\f[R] (elementary OS)
.IP \[bu] 2
\f[V]endeavouros\f[R] (EndeavourOS)
.IP \[bu] 2
\f[V]endless\f[R] (Endless OS)
.IP \[bu] 2
\f[V]fedora\f[R] (Fedora)
.IP \[bu] 2
\f[V]freebsd\f[R] (FreeBSD)
.IP \[bu] 2
\f[V]freedos\f[R] (FreeDOS)
.IP \[bu] 2
\f[V]fvoid\f[R] (F-Void)
.IP \[bu] 2
\f[V]gabeeos\f[R] (gabeeOS Linux)
.IP \[bu] 2
\f[V]garuda\f[R] (Garuda Linux)
.IP \[bu] 2
\f[V]gentoo\f[R] (Gentoo)
@ -375,12 +431,16 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]haiku\f[R] (Haiku)
.IP \[bu] 2
\f[V]holoiso\f[R] (Steam OS HoloISO)
.IP \[bu] 2
\f[V]kali\f[R] (Kali)
.IP \[bu] 2
\f[V]kdeneon\f[R] (KDE Neon)
.IP \[bu] 2
\f[V]kolibrios\f[R] (KolibriOS)
.IP \[bu] 2
\f[V]linuxlite\f[R] (Linux Lite)
.IP \[bu] 2
\f[V]linuxmint\f[R] (Linux Mint)
.IP \[bu] 2
\f[V]lmde\f[R] (Linux Mint Debian Edition)
@ -389,6 +449,8 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]manjaro\f[R] (Manjaro)
.IP \[bu] 2
\f[V]miyolinux\f[R] (Miyo Linux)
.IP \[bu] 2
\f[V]mxlinux\f[R] (MX Linux)
.IP \[bu] 2
\f[V]netboot\f[R] (netboot.xyz)
@ -399,30 +461,64 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]openbsd\f[R] (OpenBSD)
.IP \[bu] 2
\f[V]openindiana\f[R] (OpenIndiana)
.IP \[bu] 2
\f[V]opensuse\f[R] (openSUSE)
.IP \[bu] 2
\f[V]oraclelinux\f[R] (Oracle Linux)
.IP \[bu] 2
\f[V]peppermint\f[R] (PeppermintOS)
.IP \[bu] 2
\f[V]popos\f[R] (Pop!_OS)
.IP \[bu] 2
\f[V]porteus\f[R] (Porteus)
.IP \[bu] 2
\f[V]pureos\f[R] (PureOS)
.IP \[bu] 2
\f[V]reactos\f[R] (ReactOS)
.IP \[bu] 2
\f[V]rebornos\f[R] (RebornOS)
.IP \[bu] 2
\f[V]rockylinux\f[R] (Rocky Linux)
.IP \[bu] 2
\f[V]siduction\f[R] (Siduction)
.IP \[bu] 2
\f[V]slackware\f[R] (Slackware)
.IP \[bu] 2
\f[V]slax\f[R] (Slax)
.IP \[bu] 2
\f[V]slitaz\f[R] (SliTaz GNU/Linux)
.IP \[bu] 2
\f[V]solus\f[R] (Solus)
.IP \[bu] 2
\f[V]sparkylinux\f[R] (SparkyLinux)
.IP \[bu] 2
\f[V]spiral\f[R] (SpiralLinux)
.IP \[bu] 2
\f[V]tails\f[R] (Tails)
.IP \[bu] 2
\f[V]tinycore\f[R] (Tiny Core Linux)
.IP \[bu] 2
\f[V]trisquel\f[R] (Trisquel)
.IP \[bu] 2
\f[V]truenas-core\f[R] (TrueNAS Core)
.IP \[bu] 2
\f[V]truenas-scale\f[R] (TrueNAS Scale)
.IP \[bu] 2
\f[V]tuxedoos\f[R] (TuxedoOS)
.IP \[bu] 2
\f[V]vanillaos\f[R] (Vanilla OS)
.IP \[bu] 2
\f[V]ventoy\f[R] (Ventoy)
.IP \[bu] 2
\f[V]voidpup\f[R] (Void Puppy)
.IP \[bu] 2
\f[V]void\f[R] (Void Linux)
.IP \[bu] 2
\f[V]vxlinux\f[R] (VX Linux)
.IP \[bu] 2
\f[V]xerolinux\f[R] (XeroLinux)
.IP \[bu] 2
\f[V]zorin\f[R] (Zorin OS)
.PP
Or you can download a Linux image and manually create a VM
@ -473,7 +569,8 @@ quickemu --vm macos-catalina.conf
.fi
.PP
macOS \f[V]high-sierra\f[R], \f[V]mojave\f[R], \f[V]catalina\f[R],
\f[V]big-sur\f[R] and \f[V]monterey\f[R] are supported.
\f[V]big-sur\f[R], \f[V]monterey\f[R] and \f[V]ventura\f[R] are
supported.
.IP \[bu] 2
Use cursor keys and enter key to select the \f[B]macOS Base System\f[R]
.IP \[bu] 2
@ -483,13 +580,14 @@ From \f[B]macOS Utilities\f[R]
Click \f[B]Disk Utility\f[R] and \f[B]Continue\f[R]
.RS 2
.IP \[bu] 2
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list and
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list (on
Big Sur and above use \f[V]Apple Inc. VirtIO Block Device\f[R]) and
click \f[B]Erase\f[R].
.IP \[bu] 2
Enter a \f[V]Name:\f[R] for the disk
.IP \[bu] 2
If you are installing macOS Mojave or later (Catalina, Big Sur, and
Monterey), choose any of the APFS options as the filesystem.
If you are installing macOS Mojave or later (Catalina, Big Sur, Monterey
and Ventura), choose any of the APFS options as the filesystem.
MacOS Extended may not work.
.RE
.IP \[bu] 2
@ -608,6 +706,8 @@ Catalina \f[B](Recommended)\f[R]
Big Sur
.IP \[bu] 2
Monterey
.IP \[bu] 2
Ventura
.RE
.IP \[bu] 2
\f[V]quickemu\f[R] will automatically download the required
@ -677,21 +777,17 @@ sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
.fi
.PP
Now reboot, and the App Store should work.
.SS Windows 10 & 11 Guests
.SS Windows 8, 10 & 11 Guests
.PP
\f[V]quickget\f[R] can not download
\f[V]quickget\f[R] can download
Windows10 (https://www.microsoft.com/software-download/windows10) and
Windows 11 (https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
automatically and create an optimised virtual machine configuration.
This configuration also includes the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
\f[V]quickget\f[R] can automatically download Windows 8.1, Windows
10 (https://www.microsoft.com/en-gb/software-download/windows10ISO) and
Windows 11 (https://www.microsoft.com/en-gb/software-download/windows11)
along with the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
.PP
Windows 8.1 is also supported but doesn\[cq]t feature any automated
installation or driver optimisation.
.IP
.nf
\f[C]
@ -704,7 +800,7 @@ Complete the installation as you normally would.
.IP \[bu] 2
All relevant drivers and services should be installed automatically.
.IP \[bu] 2
A local adminstrator user account is automatically created, with these
A local administrator user account is automatically created, with these
credentials:
.RS 2
.IP \[bu] 2
@ -722,7 +818,7 @@ disk_img=\[dq]windows-11/disk.qcow2\[dq]
iso=\[dq]windows-11/windows-11.iso\[dq]
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
tpm=\[dq]on\[dq]
secureboot=\[dq]on\[dq]
secureboot=\[dq]off\[dq]
\f[R]
.fi
.IP \[bu] 2
@ -744,6 +840,7 @@ Usage
quickemu --vm ubuntu.conf
You can also pass optional parameters
--access : Enable remote spice access support. \[aq]local\[aq] (default), \[aq]remote\[aq], \[aq]clientipaddress\[aq]
--braille : Enable braille support. Requires SDL.
--delete-disk : Delete the disk image and EFI variables
--delete-vm : Delete the entire VM and it\[aq]s configuration
@ -751,6 +848,7 @@ You can also pass optional parameters
--fullscreen : Starts VM in full screen mode (Ctl+Alt+f to exit)
--ignore-msrs-always : Configure KVM to always ignore unhandled machine-specific registers
--screen <screen> : Use specified screen to determine the window size.
--screenpct <percent> : Percent of fullscreen for VM if --fullscreen is not specified.
--shortcut : Create a desktop shortcut
--snapshot apply <tag> : Apply/restore a snapshot.
--snapshot create <tag> : Create a snapshot.
@ -760,7 +858,7 @@ You can also pass optional parameters
--viewer <viewer> : Choose an alternative viewer. \[at]Options: \[aq]spicy\[aq] (default), \[aq]remote-viewer\[aq], \[aq]none\[aq]
--ssh-port <port> : Set ssh-port manually
--spice-port <port> : Set spice-port manually
--public-dir <path> : expose share directory. \[at]Options: \[aq]\[aq] (default: xdg-user-dir PUBLICSHARE), \[aq]<directory>\[aq], \[aq]none\[aq]
--public-dir <path> : Expose share directory. \[at]Options: \[aq]\[aq] (default: xdg-user-dir PUBLICSHARE), \[aq]<directory>\[aq], \[aq]none\[aq]
--monitor <type> : Set monitor connection type. \[at]Options: \[aq]socket\[aq] (default), \[aq]telnet\[aq], \[aq]none\[aq]
--monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: \[aq]localhost\[aq])
--monitor-telnet-port <port> : Set telnet port for monitor. (default: \[aq]4440\[aq])
@ -772,6 +870,7 @@ You can also pass optional parameters
--keyboard_layout <layout> : Set keyboard layout.
--mouse <type> : Set mouse. \[at]Options: \[aq]tablet\[aq] (default), \[aq]ps2\[aq], \[aq]usb\[aq], \[aq]virtio\[aq]
--usb-controller <type> : Set usb-controller. \[at]Options: \[aq]ehci\[aq] (default), \[aq]xhci\[aq], \[aq]none\[aq]
--sound-card <type> : Set sound card. \[at]Options: \[aq]intel-hda\[aq] (default), \[aq]ac97\[aq], \[aq]es1370\[aq], \[aq]sb16\[aq], \[aq]none\[aq]
--extra_args <arguments> : Pass additional arguments to qemu
--version : Print version
\f[R]
@ -841,6 +940,12 @@ The above uses the 2560x1440 screen to compute the size of the window,
which Quickemu sizes to 2048x1152.
Without the \f[V]--screen\f[R] option, Quickemu would have used the
1920x1080 monitor which results in a window size of 1664x936.
.PP
The `\[en]screenpct' is an optional integer value between 25 <= pct <
100 which will override system default screen sizes.
The VM size will be `pct' of the chosen screen.
\f[B]If \[en]fullscreen is chosen screen will be fullsize instead of
being scaled down by \[en]screenpct value.\f[R]
.SH References
.PP
Useful reference that assisted the development of Quickemu.

View File

@ -1,6 +1,6 @@
---
author: Martin Wimpress
date: February 4, 2023
date: November 17, 2023
footer: quickemu
header: Quickemu User Manual
section: 1
@ -30,11 +30,16 @@ You can also pass optional parameters
**--braille**
: Enable braille support. Requires SDL.
**--delete**
**--delete-disk**
: Delete the disk image.
**--display**
: Select display backend. 'sdl' (default), 'gtk', 'none' or 'spice'
: Select display backend. 'sdl' (default), 'gtk', 'none', 'spice' or
'spice-app'
**--sound-card**
: Select virtual audio emulation. 'intel-hda' (default), 'ac97'
(solaris default), 'es1370', 'sb16' (freedos default) or 'none'
**--fullscreen**
: Starts VM in full screen mode (Ctl+Alt+f to exit)
@ -93,7 +98,7 @@ Windows**.
## Features
- **macOS** Monterey, Big Sur, Catalina, Mojave & High Sierra
- **Windows** 8.1, 10 and 11 including TPM 2.0
- **Windows** 10 and 11 including TPM 2.0
- [Ubuntu](https://ubuntu.com/desktop) and all the **[official Ubuntu
flavours](https://ubuntu.com/download/flavours)**
- **Over 360 operating system editions are supported!**
@ -166,9 +171,9 @@ above requirements or their equivalents.
These examples may save a little typing
Debian:
Debian (and direct derivatives such as MX Linux):
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip
sudo apt install qemu bash coreutils ovmf grep jq lsb-base procps python3 genisoimage usbutils util-linux sed spice-client-gtk libtss2-tcti-swtpm0 wget xdg-user-dirs zsync unzip
Fedora:
@ -243,9 +248,11 @@ series.
All the official Ubuntu flavours are supported, just replace `ubuntu`
with your preferred flavour.
- `edubuntu` (Edubuntu)
- `kubuntu` (Kubuntu)
- `lubuntu` (Lubuntu)
- `ubuntu-budgie` (Ubuntu Budgie)
- `ubuntucinnamon` (Ubuntu Cinnamon)
- `ubuntukylin` (Ubuntu Kylin)
- `ubuntu-mate` (Ubuntu MATE)
- `ubuntustudio` (Ubuntu Studio)
@ -253,56 +260,106 @@ with your preferred flavour.
- `ubuntu-unity` (Ubuntu Unity)
- `xubuntu` (Xubuntu)
You can also use `quickget` with options to:
``` shell
# show an OS ISO download URL for {os} {release} [edition]
quickget --show-iso-url fedora 38 Silverblue
# test if and OS ISO is available for {os} {release} [edition]
quickget --test-iso-url nixos 23.05 plasma5
# open an OS distribution homepage in a browser
quickget --open-distro-homepage ubuntu-mate
```
The `--show-iso-url` and `--test-iso-url` options **do not** work for
`Windows` (`quickget` will begin downloading the requested release and
edition of windows)
## Other Operating Systems
`quickget` also supports:
- `agarimos` (AgarimOS)
- `alma` (Alma Linux)
- `alpine` (Alpine Linux)
- `android` (Android x86)
- `antix` (Antix)
- `archcraft` (Archcraft)
- `archlinux` (Arch Linux)
- `arcolinux` (Arco Linux)
- `artixlinux` (Artix Linux)
- `athenaos` (Athenaos)
- `batocera` (Batocera)
- `bazzite` (Bazzite)
- `biglinux` (BigLinux)
- `blendos` (BlendOS)
- `bodhi` (Bodhi Linux)
- `bunsenlabs` (Bunsenlabs)
- `cachyos` (CachyOS)
- `centos-stream` (CentOS Stream)
- `cereus` (Cereus Linux)
- `chimera` (Chimera Linux)
- `debian` (Debian)
- `deepin` (Deepin)
- `devuan` (Devuan)
- `dietpi` (DietPi)
- `dragonflybsd` (DragonFlyBSD)
- `elementary` (elementary OS)
- `endeavouros` (EndeavourOS)
- `endless` (Endless OS)
- `fedora` (Fedora)
- `freebsd` (FreeBSD)
- `freedos` (FreeDOS)
- `fvoid` (F-Void)
- `gabeeos` (gabeeOS Linux)
- `garuda` (Garuda Linux)
- `gentoo` (Gentoo)
- `ghostbsd` (GhostBSD)
- `haiku` (Haiku)
- `holoiso` (Steam OS HoloISO)
- `kali` (Kali)
- `kdeneon` (KDE Neon)
- `kolibrios` (KolibriOS)
- `linuxlite` (Linux Lite)
- `linuxmint` (Linux Mint)
- `lmde` (Linux Mint Debian Edition)
- `mageia` (Mageia)
- `manjaro` (Manjaro)
- `miyolinux` (Miyo Linux)
- `mxlinux` (MX Linux)
- `netboot` (netboot.xyz)
- `netbsd` (NetBSD)
- `nixos` (NixOS)
- `openbsd` (OpenBSD)
- `openindiana` (OpenIndiana)
- `opensuse` (openSUSE)
- `oraclelinux` (Oracle Linux)
- `peppermint` (PeppermintOS)
- `popos` (Pop!\_OS)
- `porteus` (Porteus)
- `pureos` (PureOS)
- `reactos` (ReactOS)
- `rebornos` (RebornOS)
- `rockylinux` (Rocky Linux)
- `siduction` (Siduction)
- `slackware` (Slackware)
- `slax` (Slax)
- `slitaz` (SliTaz GNU/Linux)
- `solus` (Solus)
- `sparkylinux` (SparkyLinux)
- `spiral` (SpiralLinux)
- `tails` (Tails)
- `tinycore` (Tiny Core Linux)
- `trisquel` (Trisquel)
- `truenas-core` (TrueNAS Core)
- `truenas-scale` (TrueNAS Scale)
- `tuxedoos` (TuxedoOS)
- `vanillaos` (Vanilla OS)
- `ventoy` (Ventoy)
- `voidpup` (Void Puppy)
- `void` (Void Linux)
- `vxlinux` (VX Linux)
- `xerolinux` (XeroLinux)
- `zorin` (Zorin OS)
Or you can download a Linux image and manually create a VM
@ -340,18 +397,19 @@ quickget macos catalina
quickemu --vm macos-catalina.conf
```
macOS `high-sierra`, `mojave`, `catalina`, `big-sur` and `monterey` are
supported.
macOS `high-sierra`, `mojave`, `catalina`, `big-sur`, `monterey` and
`ventura` are supported.
- Use cursor keys and enter key to select the **macOS Base System**
- From **macOS Utilities**
- Click **Disk Utility** and **Continue**
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list and
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list (on
Big Sur and above use `Apple Inc. VirtIO Block Device`) and
click **Erase**.
- Enter a `Name:` for the disk
- If you are installing macOS Mojave or later (Catalina, Big
Sur, and Monterey), choose any of the APFS options as the
filesystem. MacOS Extended may not work.
Sur, Monterey and Ventura), choose any of the APFS options
as the filesystem. MacOS Extended may not work.
- Click **Erase**.
- Click **Done**.
- Close Disk Utility
@ -433,6 +491,7 @@ There are some considerations when running macOS via Quickemu.
- Catalina **(Recommended)**
- Big Sur
- Monterey
- Ventura
- `quickemu` will automatically download the required
[OpenCore](https://github.com/acidanthera/OpenCorePkg) bootloader
and OVMF firmware from [OSX-KVM](https://github.com/kholia/OSX-KVM).
@ -480,22 +539,17 @@ sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
Now reboot, and the App Store should work.
## Windows 10 & 11 Guests
## Windows 8, 10 & 11 Guests
`quickget` can not download
`quickget` can download
[Windows10](https://www.microsoft.com/software-download/windows10) and
[Windows 11](https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
automatically and create an optimised virtual machine configuration.
This configuration also includes the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
`quickget` can automatically download Windows 8.1, [Windows
10](https://www.microsoft.com/en-gb/software-download/windows10ISO) and
[Windows
11](https://www.microsoft.com/en-gb/software-download/windows11) along
with the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
Windows 8.1 is also supported but doesn't feature any automated
installation or driver optimisation.
``` bash
quickget windows 11
@ -504,7 +558,7 @@ quickemu --vm windows-11.conf
- Complete the installation as you normally would.
- All relevant drivers and services should be installed automatically.
- A local adminstrator user account is automatically created, with
- A local administrator user account is automatically created, with
these credentials:
- Username: `Quickemu`
- Password: `quickemu`
@ -517,7 +571,7 @@ disk_img="windows-11/disk.qcow2"
iso="windows-11/windows-11.iso"
fixed_iso="windows-11/virtio-win.iso"
tpm="on"
secureboot="on"
secureboot="off"
```
- `guest_os="windows"` instructs `quickemu` to optimise for Windows.
@ -534,6 +588,7 @@ Here are the usage instructions:
quickemu --vm ubuntu.conf
You can also pass optional parameters
--access : Enable remote spice access support. 'local' (default), 'remote', 'clientipaddress'
--braille : Enable braille support. Requires SDL.
--delete-disk : Delete the disk image and EFI variables
--delete-vm : Delete the entire VM and it's configuration
@ -541,6 +596,7 @@ Here are the usage instructions:
--fullscreen : Starts VM in full screen mode (Ctl+Alt+f to exit)
--ignore-msrs-always : Configure KVM to always ignore unhandled machine-specific registers
--screen <screen> : Use specified screen to determine the window size.
--screenpct <percent> : Percent of fullscreen for VM if --fullscreen is not specified.
--shortcut : Create a desktop shortcut
--snapshot apply <tag> : Apply/restore a snapshot.
--snapshot create <tag> : Create a snapshot.
@ -550,7 +606,7 @@ Here are the usage instructions:
--viewer <viewer> : Choose an alternative viewer. @Options: 'spicy' (default), 'remote-viewer', 'none'
--ssh-port <port> : Set ssh-port manually
--spice-port <port> : Set spice-port manually
--public-dir <path> : expose share directory. @Options: '' (default: xdg-user-dir PUBLICSHARE), '<directory>', 'none'
--public-dir <path> : Expose share directory. @Options: '' (default: xdg-user-dir PUBLICSHARE), '<directory>', 'none'
--monitor <type> : Set monitor connection type. @Options: 'socket' (default), 'telnet', 'none'
--monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: 'localhost')
--monitor-telnet-port <port> : Set telnet port for monitor. (default: '4440')
@ -562,6 +618,7 @@ Here are the usage instructions:
--keyboard_layout <layout> : Set keyboard layout.
--mouse <type> : Set mouse. @Options: 'tablet' (default), 'ps2', 'usb', 'virtio'
--usb-controller <type> : Set usb-controller. @Options: 'ehci' (default), 'xhci', 'none'
--sound-card <type> : Set sound card. @Options: 'intel-hda' (default), 'ac97', 'es1370', 'sb16', 'none'
--extra_args <arguments> : Pass additional arguments to qemu
--version : Print version
@ -620,6 +677,11 @@ which Quickemu sizes to 2048x1152. Without the `--screen` option,
Quickemu would have used the 1920x1080 monitor which results in a window
size of 1664x936.
The '--screenpct' is an optional integer value between 25 \<= pct \< 100
which will override system default screen sizes. The VM size will be
'pct' of the chosen screen. **If --fullscreen is chosen screen will be
fullsize instead of being scaled down by --screenpct value.**
# References
Useful reference that assisted the development of Quickemu.

View File

@ -1,4 +1,4 @@
.\" Automatically generated by Pandoc 2.19.2
.\" Automatically generated by Pandoc 2.17.1.1
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
@ -14,7 +14,7 @@
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKEMU_CONF" "1" "February 4, 2023" "quickemu_conf" "Quickemu Configuration Manual"
.TH "QUICKEMU_CONF" "1" "November 17, 2023" "quickemu_conf" "Quickemu Configuration Manual"
.hy
.SH NAME
.PP

View File

@ -1,6 +1,6 @@
---
author: Martin Wimpress
date: February 4, 2023
date: November 17, 2023
footer: quickemu_conf
header: Quickemu Configuration Manual
section: 1

View File

@ -1,4 +1,4 @@
.\" Automatically generated by Pandoc 2.19.2
.\" Automatically generated by Pandoc 2.17.1.1
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
@ -14,7 +14,7 @@
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKGET" "1" "February 4, 2023" "quickget" "Quickget User Manual"
.TH "QUICKGET" "1" "November 17, 2023" "quickget" "Quickget User Manual"
.hy
.SH NAME
.PP
@ -35,6 +35,15 @@ show version (from Quickemu)
\f[B]list | list_csv | list_json\f[R]
provide a csv list of all supported guest OSes, versions and variants.
.TP
\f[B]\f[VB]--show-iso-url\f[B] | -s\f[R] {\f[B]os\f[R]} {\f[B]release\f[R]} [\f[B]edition\f[R]]
show ISO download URL
.TP
\f[B]\f[VB]--test-iso-url\f[B] | -t\f[R] {\f[B]os\f[R]} {\f[B]release\f[R]} [\f[B]edition\f[R]]
test if ISO is available
.TP
\f[B]\f[VB]--open-distro-homepage\f[B] | -o\f[R] {\f[B]os\f[R]}
open OS homepage in browser
.TP
\f[B][OS] [Release] [Edition]\f[R]
specify the OS and release (and optional edition) if insufficient input
is provided a list of missing options will be reported and the script
@ -92,12 +101,16 @@ switch to a new series.
All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu\f[R] with your preferred flavour.
.IP \[bu] 2
\f[V]edubuntu\f[R] (Edubuntu)
.IP \[bu] 2
\f[V]kubuntu\f[R] (Kubuntu)
.IP \[bu] 2
\f[V]lubuntu\f[R] (Lubuntu)
.IP \[bu] 2
\f[V]ubuntu-budgie\f[R] (Ubuntu Budgie)
.IP \[bu] 2
\f[V]ubuntucinnamon\f[R] (Ubuntu Cinnamon)
.IP \[bu] 2
\f[V]ubuntukylin\f[R] (Ubuntu Kylin)
.IP \[bu] 2
\f[V]ubuntu-mate\f[R] (Ubuntu MATE)
@ -109,46 +122,93 @@ All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu-unity\f[R] (Ubuntu Unity)
.IP \[bu] 2
\f[V]xubuntu\f[R] (Xubuntu)
.PP
You can also use \f[V]quickget\f[R] with options to:
.IP
.nf
\f[C]
# show an OS ISO download URL for {os} {release} [edition]
quickget --show-iso-url fedora 38 Silverblue
# test if and OS ISO is available for {os} {release} [edition]
quickget --test-iso-url nixos 23.05 plasma5
# open an OS distribution homepage in a browser
quickget --open-distro-homepage ubuntu-mate
\f[R]
.fi
.PP
The \f[V]--show-iso-url\f[R] and \f[V]--test-iso-url\f[R] options
\f[B]do not\f[R] work for \f[V]Windows\f[R] (\f[V]quickget\f[R] will
begin downloading the requested release and edition of windows)
.SS Other Operating Systems
.PP
\f[V]quickget\f[R] also supports:
.IP \[bu] 2
\f[V]agarimos\f[R] (AgarimOS)
.IP \[bu] 2
\f[V]alma\f[R] (Alma Linux)
.IP \[bu] 2
\f[V]alpine\f[R] (Alpine Linux)
.IP \[bu] 2
\f[V]android\f[R] (Android x86)
.IP \[bu] 2
\f[V]antix\f[R] (Antix)
.IP \[bu] 2
\f[V]archcraft\f[R] (Archcraft)
.IP \[bu] 2
\f[V]archlinux\f[R] (Arch Linux)
.IP \[bu] 2
\f[V]arcolinux\f[R] (Arco Linux)
.IP \[bu] 2
\f[V]artixlinux\f[R] (Artix Linux)
.IP \[bu] 2
\f[V]athenaos\f[R] (Athenaos)
.IP \[bu] 2
\f[V]batocera\f[R] (Batocera)
.IP \[bu] 2
\f[V]bazzite\f[R] (Bazzite)
.IP \[bu] 2
\f[V]biglinux\f[R] (BigLinux)
.IP \[bu] 2
\f[V]blendos\f[R] (BlendOS)
.IP \[bu] 2
\f[V]bodhi\f[R] (Bodhi Linux)
.IP \[bu] 2
\f[V]bunsenlabs\f[R] (Bunsenlabs)
.IP \[bu] 2
\f[V]cachyos\f[R] (CachyOS)
.IP \[bu] 2
\f[V]centos-stream\f[R] (CentOS Stream)
.IP \[bu] 2
\f[V]cereus\f[R] (Cereus Linux)
.IP \[bu] 2
\f[V]chimera\f[R] (Chimera Linux)
.IP \[bu] 2
\f[V]debian\f[R] (Debian)
.IP \[bu] 2
\f[V]deepin\f[R] (Deepin)
.IP \[bu] 2
\f[V]devuan\f[R] (Devuan)
.IP \[bu] 2
\f[V]dietpi\f[R] (DietPi)
.IP \[bu] 2
\f[V]dragonflybsd\f[R] (DragonFlyBSD)
.IP \[bu] 2
\f[V]elementary\f[R] (elementary OS)
.IP \[bu] 2
\f[V]endeavouros\f[R] (EndeavourOS)
.IP \[bu] 2
\f[V]endless\f[R] (Endless OS)
.IP \[bu] 2
\f[V]fedora\f[R] (Fedora)
.IP \[bu] 2
\f[V]freebsd\f[R] (FreeBSD)
.IP \[bu] 2
\f[V]freedos\f[R] (FreeDOS)
.IP \[bu] 2
\f[V]fvoid\f[R] (F-Void)
.IP \[bu] 2
\f[V]gabeeos\f[R] (gabeeOS Linux)
.IP \[bu] 2
\f[V]garuda\f[R] (Garuda Linux)
.IP \[bu] 2
\f[V]gentoo\f[R] (Gentoo)
@ -157,12 +217,16 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]haiku\f[R] (Haiku)
.IP \[bu] 2
\f[V]holoiso\f[R] (Steam OS HoloISO)
.IP \[bu] 2
\f[V]kali\f[R] (Kali)
.IP \[bu] 2
\f[V]kdeneon\f[R] (KDE Neon)
.IP \[bu] 2
\f[V]kolibrios\f[R] (KolibriOS)
.IP \[bu] 2
\f[V]linuxlite\f[R] (Linux Lite)
.IP \[bu] 2
\f[V]linuxmint\f[R] (Linux Mint)
.IP \[bu] 2
\f[V]lmde\f[R] (Linux Mint Debian Edition)
@ -171,6 +235,8 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]manjaro\f[R] (Manjaro)
.IP \[bu] 2
\f[V]miyolinux\f[R] (Miyo Linux)
.IP \[bu] 2
\f[V]mxlinux\f[R] (MX Linux)
.IP \[bu] 2
\f[V]netboot\f[R] (netboot.xyz)
@ -181,30 +247,64 @@ All the official Ubuntu flavours are supported, just replace
.IP \[bu] 2
\f[V]openbsd\f[R] (OpenBSD)
.IP \[bu] 2
\f[V]openindiana\f[R] (OpenIndiana)
.IP \[bu] 2
\f[V]opensuse\f[R] (openSUSE)
.IP \[bu] 2
\f[V]oraclelinux\f[R] (Oracle Linux)
.IP \[bu] 2
\f[V]peppermint\f[R] (PeppermintOS)
.IP \[bu] 2
\f[V]popos\f[R] (Pop!_OS)
.IP \[bu] 2
\f[V]porteus\f[R] (Porteus)
.IP \[bu] 2
\f[V]pureos\f[R] (PureOS)
.IP \[bu] 2
\f[V]reactos\f[R] (ReactOS)
.IP \[bu] 2
\f[V]rebornos\f[R] (RebornOS)
.IP \[bu] 2
\f[V]rockylinux\f[R] (Rocky Linux)
.IP \[bu] 2
\f[V]siduction\f[R] (Siduction)
.IP \[bu] 2
\f[V]slackware\f[R] (Slackware)
.IP \[bu] 2
\f[V]slax\f[R] (Slax)
.IP \[bu] 2
\f[V]slitaz\f[R] (SliTaz GNU/Linux)
.IP \[bu] 2
\f[V]solus\f[R] (Solus)
.IP \[bu] 2
\f[V]sparkylinux\f[R] (SparkyLinux)
.IP \[bu] 2
\f[V]spiral\f[R] (SpiralLinux)
.IP \[bu] 2
\f[V]tails\f[R] (Tails)
.IP \[bu] 2
\f[V]tinycore\f[R] (Tiny Core Linux)
.IP \[bu] 2
\f[V]trisquel\f[R] (Trisquel)
.IP \[bu] 2
\f[V]truenas-core\f[R] (TrueNAS Core)
.IP \[bu] 2
\f[V]truenas-scale\f[R] (TrueNAS Scale)
.IP \[bu] 2
\f[V]tuxedoos\f[R] (TuxedoOS)
.IP \[bu] 2
\f[V]vanillaos\f[R] (Vanilla OS)
.IP \[bu] 2
\f[V]ventoy\f[R] (Ventoy)
.IP \[bu] 2
\f[V]voidpup\f[R] (Void Puppy)
.IP \[bu] 2
\f[V]void\f[R] (Void Linux)
.IP \[bu] 2
\f[V]vxlinux\f[R] (VX Linux)
.IP \[bu] 2
\f[V]xerolinux\f[R] (XeroLinux)
.IP \[bu] 2
\f[V]zorin\f[R] (Zorin OS)
.PP
Or you can download a Linux image and manually create a VM
@ -255,7 +355,8 @@ quickemu --vm macos-catalina.conf
.fi
.PP
macOS \f[V]high-sierra\f[R], \f[V]mojave\f[R], \f[V]catalina\f[R],
\f[V]big-sur\f[R] and \f[V]monterey\f[R] are supported.
\f[V]big-sur\f[R], \f[V]monterey\f[R] and \f[V]ventura\f[R] are
supported.
.IP \[bu] 2
Use cursor keys and enter key to select the \f[B]macOS Base System\f[R]
.IP \[bu] 2
@ -265,13 +366,14 @@ From \f[B]macOS Utilities\f[R]
Click \f[B]Disk Utility\f[R] and \f[B]Continue\f[R]
.RS 2
.IP \[bu] 2
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list and
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list (on
Big Sur and above use \f[V]Apple Inc. VirtIO Block Device\f[R]) and
click \f[B]Erase\f[R].
.IP \[bu] 2
Enter a \f[V]Name:\f[R] for the disk
.IP \[bu] 2
If you are installing macOS Mojave or later (Catalina, Big Sur, and
Monterey), choose any of the APFS options as the filesystem.
If you are installing macOS Mojave or later (Catalina, Big Sur, Monterey
and Ventura), choose any of the APFS options as the filesystem.
MacOS Extended may not work.
.RE
.IP \[bu] 2
@ -390,6 +492,8 @@ Catalina \f[B](Recommended)\f[R]
Big Sur
.IP \[bu] 2
Monterey
.IP \[bu] 2
Ventura
.RE
.IP \[bu] 2
\f[V]quickemu\f[R] will automatically download the required
@ -459,21 +563,17 @@ sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
.fi
.PP
Now reboot, and the App Store should work.
.SS Windows 10 & 11 Guests
.SS Windows 8, 10 & 11 Guests
.PP
\f[V]quickget\f[R] can not download
\f[V]quickget\f[R] can download
Windows10 (https://www.microsoft.com/software-download/windows10) and
Windows 11 (https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
automatically and create an optimised virtual machine configuration.
This configuration also includes the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
\f[V]quickget\f[R] can automatically download Windows 8.1, Windows
10 (https://www.microsoft.com/en-gb/software-download/windows10ISO) and
Windows 11 (https://www.microsoft.com/en-gb/software-download/windows11)
along with the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
.PP
Windows 8.1 is also supported but doesn\[cq]t feature any automated
installation or driver optimisation.
.IP
.nf
\f[C]
@ -486,7 +586,7 @@ Complete the installation as you normally would.
.IP \[bu] 2
All relevant drivers and services should be installed automatically.
.IP \[bu] 2
A local adminstrator user account is automatically created, with these
A local administrator user account is automatically created, with these
credentials:
.RS 2
.IP \[bu] 2
@ -504,7 +604,7 @@ disk_img=\[dq]windows-11/disk.qcow2\[dq]
iso=\[dq]windows-11/windows-11.iso\[dq]
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
tpm=\[dq]on\[dq]
secureboot=\[dq]on\[dq]
secureboot=\[dq]off\[dq]
\f[R]
.fi
.IP \[bu] 2

View File

@ -1,6 +1,6 @@
---
author: Martin Wimpress
date: February 4, 2023
date: November 17, 2023
footer: quickget
header: Quickget User Manual
section: 1
@ -29,6 +29,15 @@ configuration for `quickemu` to use to build and run
: provide a csv list of all supported guest OSes, versions and
variants.
**`--show-iso-url` \| -s** {**os**} {**release**} \[**edition**\]
: show ISO download URL
**`--test-iso-url` \| -t** {**os**} {**release**} \[**edition**\]
: test if ISO is available
**`--open-distro-homepage` \| -o** {**os**}
: open OS homepage in browser
**\[OS\] \[Release\] \[Edition\]**
: specify the OS and release (and optional edition) if insufficient
input is provided a list of missing options will be reported and the
@ -75,9 +84,11 @@ series.
All the official Ubuntu flavours are supported, just replace `ubuntu`
with your preferred flavour.
- `edubuntu` (Edubuntu)
- `kubuntu` (Kubuntu)
- `lubuntu` (Lubuntu)
- `ubuntu-budgie` (Ubuntu Budgie)
- `ubuntucinnamon` (Ubuntu Cinnamon)
- `ubuntukylin` (Ubuntu Kylin)
- `ubuntu-mate` (Ubuntu MATE)
- `ubuntustudio` (Ubuntu Studio)
@ -85,56 +96,106 @@ with your preferred flavour.
- `ubuntu-unity` (Ubuntu Unity)
- `xubuntu` (Xubuntu)
You can also use `quickget` with options to:
``` shell
# show an OS ISO download URL for {os} {release} [edition]
quickget --show-iso-url fedora 38 Silverblue
# test if and OS ISO is available for {os} {release} [edition]
quickget --test-iso-url nixos 23.05 plasma5
# open an OS distribution homepage in a browser
quickget --open-distro-homepage ubuntu-mate
```
The `--show-iso-url` and `--test-iso-url` options **do not** work for
`Windows` (`quickget` will begin downloading the requested release and
edition of windows)
## Other Operating Systems
`quickget` also supports:
- `agarimos` (AgarimOS)
- `alma` (Alma Linux)
- `alpine` (Alpine Linux)
- `android` (Android x86)
- `antix` (Antix)
- `archcraft` (Archcraft)
- `archlinux` (Arch Linux)
- `arcolinux` (Arco Linux)
- `artixlinux` (Artix Linux)
- `athenaos` (Athenaos)
- `batocera` (Batocera)
- `bazzite` (Bazzite)
- `biglinux` (BigLinux)
- `blendos` (BlendOS)
- `bodhi` (Bodhi Linux)
- `bunsenlabs` (Bunsenlabs)
- `cachyos` (CachyOS)
- `centos-stream` (CentOS Stream)
- `cereus` (Cereus Linux)
- `chimera` (Chimera Linux)
- `debian` (Debian)
- `deepin` (Deepin)
- `devuan` (Devuan)
- `dietpi` (DietPi)
- `dragonflybsd` (DragonFlyBSD)
- `elementary` (elementary OS)
- `endeavouros` (EndeavourOS)
- `endless` (Endless OS)
- `fedora` (Fedora)
- `freebsd` (FreeBSD)
- `freedos` (FreeDOS)
- `fvoid` (F-Void)
- `gabeeos` (gabeeOS Linux)
- `garuda` (Garuda Linux)
- `gentoo` (Gentoo)
- `ghostbsd` (GhostBSD)
- `haiku` (Haiku)
- `holoiso` (Steam OS HoloISO)
- `kali` (Kali)
- `kdeneon` (KDE Neon)
- `kolibrios` (KolibriOS)
- `linuxlite` (Linux Lite)
- `linuxmint` (Linux Mint)
- `lmde` (Linux Mint Debian Edition)
- `mageia` (Mageia)
- `manjaro` (Manjaro)
- `miyolinux` (Miyo Linux)
- `mxlinux` (MX Linux)
- `netboot` (netboot.xyz)
- `netbsd` (NetBSD)
- `nixos` (NixOS)
- `openbsd` (OpenBSD)
- `openindiana` (OpenIndiana)
- `opensuse` (openSUSE)
- `oraclelinux` (Oracle Linux)
- `peppermint` (PeppermintOS)
- `popos` (Pop!\_OS)
- `porteus` (Porteus)
- `pureos` (PureOS)
- `reactos` (ReactOS)
- `rebornos` (RebornOS)
- `rockylinux` (Rocky Linux)
- `siduction` (Siduction)
- `slackware` (Slackware)
- `slax` (Slax)
- `slitaz` (SliTaz GNU/Linux)
- `solus` (Solus)
- `sparkylinux` (SparkyLinux)
- `spiral` (SpiralLinux)
- `tails` (Tails)
- `tinycore` (Tiny Core Linux)
- `trisquel` (Trisquel)
- `truenas-core` (TrueNAS Core)
- `truenas-scale` (TrueNAS Scale)
- `tuxedoos` (TuxedoOS)
- `vanillaos` (Vanilla OS)
- `ventoy` (Ventoy)
- `voidpup` (Void Puppy)
- `void` (Void Linux)
- `vxlinux` (VX Linux)
- `xerolinux` (XeroLinux)
- `zorin` (Zorin OS)
Or you can download a Linux image and manually create a VM
@ -172,18 +233,19 @@ quickget macos catalina
quickemu --vm macos-catalina.conf
```
macOS `high-sierra`, `mojave`, `catalina`, `big-sur` and `monterey` are
supported.
macOS `high-sierra`, `mojave`, `catalina`, `big-sur`, `monterey` and
`ventura` are supported.
- Use cursor keys and enter key to select the **macOS Base System**
- From **macOS Utilities**
- Click **Disk Utility** and **Continue**
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list and
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list (on
Big Sur and above use `Apple Inc. VirtIO Block Device`) and
click **Erase**.
- Enter a `Name:` for the disk
- If you are installing macOS Mojave or later (Catalina, Big
Sur, and Monterey), choose any of the APFS options as the
filesystem. MacOS Extended may not work.
Sur, Monterey and Ventura), choose any of the APFS options
as the filesystem. MacOS Extended may not work.
- Click **Erase**.
- Click **Done**.
- Close Disk Utility
@ -265,6 +327,7 @@ There are some considerations when running macOS via Quickemu.
- Catalina **(Recommended)**
- Big Sur
- Monterey
- Ventura
- `quickemu` will automatically download the required
[OpenCore](https://github.com/acidanthera/OpenCorePkg) bootloader
and OVMF firmware from [OSX-KVM](https://github.com/kholia/OSX-KVM).
@ -312,22 +375,17 @@ sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
Now reboot, and the App Store should work.
## Windows 10 & 11 Guests
## Windows 8, 10 & 11 Guests
`quickget` can not download
`quickget` can download
[Windows10](https://www.microsoft.com/software-download/windows10) and
[Windows 11](https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
automatically and create an optimised virtual machine configuration.
This configuration also includes the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
`quickget` can automatically download Windows 8.1, [Windows
10](https://www.microsoft.com/en-gb/software-download/windows10ISO) and
[Windows
11](https://www.microsoft.com/en-gb/software-download/windows11) along
with the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
Windows 8.1 is also supported but doesn't feature any automated
installation or driver optimisation.
``` bash
quickget windows 11
@ -336,7 +394,7 @@ quickemu --vm windows-11.conf
- Complete the installation as you normally would.
- All relevant drivers and services should be installed automatically.
- A local adminstrator user account is automatically created, with
- A local administrator user account is automatically created, with
these credentials:
- Username: `Quickemu`
- Password: `quickemu`
@ -349,7 +407,7 @@ disk_img="windows-11/disk.qcow2"
iso="windows-11/windows-11.iso"
fixed_iso="windows-11/virtio-win.iso"
tpm="on"
secureboot="on"
secureboot="off"
```
- `guest_os="windows"` instructs `quickemu` to optimise for Windows.

11
docs/simplex.svg Normal file
View File

@ -0,0 +1,11 @@
<svg width="161" height="40" viewBox="0 0 161 40" fill="none" xmlns="http://www.w3.org/2000/svg">
<path fill-rule="evenodd" clip-rule="evenodd" d="M8.36956 9.95312C9.07658 9.95312 9.77404 10.0183 10.462 10.1487C11.1499 10.2791 11.8091 10.4467 12.4397 10.6516C13.0703 10.8565 13.6579 11.0894 14.2025 11.3502C14.7471 11.6109 15.2487 11.8717 15.7073 12.1325L13.6435 15.9324L13.6153 15.9014C13.5338 15.822 13.3426 15.6926 13.0416 15.5133C12.6977 15.3084 12.2677 15.0942 11.7518 14.8707C11.2359 14.6472 10.6721 14.4516 10.0607 14.2839C9.4492 14.1163 8.83772 14.0325 8.22625 14.0325C6.54469 14.0325 5.70391 14.582 5.70391 15.681C5.70391 16.0162 5.79468 16.2956 5.97621 16.5192C6.15774 16.7427 6.42526 16.9429 6.77877 17.1199C7.13228 17.2969 7.57656 17.4598 8.1116 17.6089C8.64664 17.7579 9.26767 17.9255 9.97469 18.1118C10.9492 18.3726 11.8282 18.6566 12.6117 18.964C13.3951 19.2713 14.0591 19.6532 14.6037 20.1095C15.1483 20.5659 15.5687 21.1201 15.8649 21.772C16.1611 22.424 16.3092 23.2063 16.3092 24.119C16.3092 25.2367 16.0942 26.182 15.6643 26.955C15.2343 27.728 14.6658 28.352 13.9588 28.827C13.2518 29.302 12.4397 29.6466 11.5225 29.8608C10.6053 30.075 9.65939 30.1821 8.68486 30.1821C7.93962 30.1821 7.17528 30.1263 6.39182 30.0145C5.60837 29.9027 4.84403 29.7398 4.09879 29.5255C3.35356 29.3113 2.63221 29.0552 1.93475 28.7572C1.23728 28.4591 0.592366 28.1145 0 27.7234L2.06373 23.7279L2.10045 23.7667C2.20495 23.8665 2.44112 24.0305 2.80896 24.2587C3.22935 24.5195 3.75006 24.7803 4.37109 25.0411C4.99212 25.3018 5.68481 25.5347 6.44915 25.7396C7.21349 25.9445 7.98739 26.0469 8.77084 26.0469C10.4333 26.0469 11.2645 25.5533 11.2645 24.5661C11.2645 24.1935 11.1403 23.8862 10.8919 23.644C10.6435 23.4019 10.2995 23.183 9.86003 22.9874C9.42054 22.7918 8.89983 22.6102 8.29791 22.4426C7.69599 22.2749 7.04152 22.0887 6.3345 21.8838C5.39818 21.6044 4.58606 21.3017 3.89815 20.9757C3.21024 20.6497 2.64176 20.2725 2.19271 19.8441C1.74366 19.4157 1.40926 18.9221 1.18951 18.3633C0.969761 17.8044 0.859887 17.1525 0.859887 16.4074C0.859887 15.3643 1.06053 14.4423 1.46181 13.6413C1.86309 12.8403 2.40768 12.1651 3.09559 11.6156C3.7835 11.0661 4.58129 10.6516 5.48894 10.3722C6.3966 10.0928 7.35681 9.95312 8.36956 9.95312ZM27.1234 10.1208V29.9586H22.4226V10.1208H27.1234ZM39.4853 10.1208L44.7593 20.4867L50.0619 10.1208H55.1353V29.9586H50.4345V18.0839L46.0205 26.7175H43.4981L39.084 18.0839V29.9586H34.3833V10.1208H39.4853ZM86.6338 10.1208V25.9352H96.4939V29.9586H81.9331V10.1208H86.6338ZM115.547 10.1208V14.1442H106.203V18H114.229V21.7161H106.203V25.9352H115.805V29.9586H101.502V10.1208H115.547ZM70.5198 10.1208L70.8416 10.128C71.6918 10.1666 72.4779 10.3598 73.1998 10.7075C74.0119 11.0987 74.7093 11.6109 75.2922 12.2443C75.875 12.8776 76.3336 13.5947 76.668 14.3957C77.0024 15.1967 77.1696 16.0069 77.1696 16.8265C77.1696 17.702 77.0119 18.5402 76.6966 19.3412C76.3813 20.1421 75.9419 20.8593 75.3781 21.4926C74.8144 22.1259 74.1313 22.6289 73.3287 23.0014C72.6154 23.3326 71.834 23.5165 70.9848 23.5533L70.6631 23.5602H66.5356V29.9586H61.8349V10.1208H70.5198ZM70.2045 14.1442H66.5356V19.5647H70.3765C70.9306 19.5647 71.4083 19.3319 71.8096 18.8662C72.2109 18.4005 72.4115 17.7206 72.4115 16.8265C72.4115 16.3608 72.3494 15.9604 72.2252 15.6251C72.101 15.2898 71.9338 15.0104 71.7236 14.7869C71.5134 14.5633 71.2746 14.4003 71.0071 14.2979C70.7395 14.1954 70.472 14.1442 70.2045 14.1442Z" fill="#030749"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M124.336 10.1101L130.957 16.689L137.762 9.92721L141.072 13.2167L134.267 19.9784L140.888 26.5575L137.486 29.9384L130.865 23.3592L124.06 30.1213L120.75 26.8318L127.554 20.0699L120.934 13.491L124.336 10.1101Z" fill="#030749"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M137.433 30L140.809 26.6454L140.807 26.6445L147.56 19.936L140.936 13.3552L140.937 13.3546L137.625 10.0637L131.002 3.48203L134.377 0.127456L141.001 6.70925L147.753 0L151.065 3.29085L144.312 10L150.936 16.5815L157.688 9.87254L161 13.1634L154.247 19.8722L160.872 26.4542L157.496 29.8088L150.871 23.2268L144.12 29.9358L150.744 36.518L147.368 39.8725L140.744 33.2904L133.993 40L130.681 36.7092L137.433 30Z" fill="url(#paint0_linear_40_164)"/>
<defs>
<linearGradient id="paint0_linear_40_164" x1="135.948" y1="-0.816326" x2="132.096" y2="36.9857" gradientUnits="userSpaceOnUse">
<stop stop-color="#01F1FF"/>
<stop offset="1" stop-color="#0197FF"/>
</linearGradient>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.3 KiB

View File

Before

Width:  |  Height:  |  Size: 4.5 KiB

After

Width:  |  Height:  |  Size: 4.5 KiB

BIN
docs/tux23.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 840 B

64
documents/Makefile Normal file
View File

@ -0,0 +1,64 @@
include pandoc-man.mk
ifeq ($(PREFIX),)
PREFIX := /usr
endif
datarootdir := $(PREFIX)/share
datadir := $(datarootdir)
mandir := $(datarootdir)/man
bindir := $(PREFIX)/bin
configdir := $(datarootdir)/distrohopper
ICONS_DIR := config/icons
all: distrohopper.1 quickget.1 quickemu.1 quickemu_conf.1
clean:
rm *.1
install_docs: all
install -d $(DESTDIR)$(mandir)/man1
install -m 644 distrohopper.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickget.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickemu.1 $(DESTDIR)$(mandir)/man1
install -m 644 quickemu_conf.1 $(DESTDIR)$(mandir)/man1
# install -m 644 quickgui.1 $(DESTDIR)$(mandir)/man1
install_bins:
install -d $(DESTDIR)$(bindir)
install -m 755 ../dh $(DESTDIR)$(bindir)
install -m 755 ../quickget $(DESTDIR)$(bindir)
install -m 755 ../quickemu $(DESTDIR)$(bindir)
install -m 755 ../macrecovery $(DESTDIR)$(bindir)
install_config:
install_icons:
install -d $(DESTDIR)$(datadir)/icons/distrohopper
install -m 644 $(ICONS_DIR)/*.svg $(DESTDIR)$(datadir)/icons/distrohopper
install -m 644 $(ICONS_DIR)/*.png $(DESTDIR)$(datadir)/icons/distrohopper
install: install_bins install_docs install_icons
uninstall_icons:
rm -f $(DESTDIR)$(datadir)/icons/distrohopper/*.svg
rm -f $(DESTDIR)$(datadir)/icons/distrohopper/*.png
uninstall_docs:
rm -f $(DESTDIR)$(mandir)/man1/distrohopper.1
rm -f $(DESTDIR)$(mandir)/man1/quickget.1
rm -f $(DESTDIR)$(mandir)/man1/quickemu.1
rm -f $(DESTDIR)$(mandir)/man1/quickemu_conf.1
uninstall_bins:
rm -f $(DESTDIR)$(bindir)/dh
rm -f $(DESTDIR)$(bindir)/quickget
rm -f $(DESTDIR)$(bindir)/quickemu
rm -f $(DESTDIR)$(bindir)/macrecovery
uninstall: uninstall_icons uninstall_docs uninstall_bins
.PHONY: all

View File

@ -0,0 +1,147 @@
#: dh.sh:10
msgid "Done"
msgstr "Hotovo"
#: dh.sh:11
msgid "PS: You saw some bugs?"
msgstr "PS: Viděli jste nějaké chyby?"
#: dh.sh:12
msgid "Could you please provide feedback?"
msgstr "Můžete prosím poslat zpětnou vazbu?"
#: dh.sh:13
msgid "How do you like DistroHopper?"
msgstr "Jak se vám líbí DistroHopper?"
#: dh.sh:14
msgid "What can be improved, added, changed?"
msgstr "Co může být vylepšeno, přidáno, změněno?"
#: dh.sh:15
msgid " Let me know..."
msgstr " Dejte mi vědět..."
#: dh.sh:16
msgid "Flawless distro hopping..."
msgstr "Bezchybné zkoušení distribucí..."
#: dh.sh:21
msgid "Possible arguments:"
msgstr "Možné argumenty:"
#: dh.sh:22
msgid " -h --help Show this help and exit"
msgstr " -h --help Zobrazit tuto nápovědu a skončit"
#: dh.sh:24
msgid " -d --dir Set default directory where VMs are stored"
msgstr " -d --dir Nastavit adresář kde jsou virtuální stroje uloženy"
#: dh.sh:25
msgid " -i --install Install DistroHopper"
msgstr "\t-i\t--install\t\tInstalovat DistroHopper"
#: dh.sh:27
msgid " -m --mode Portable mode"
msgstr "\t-m\t--mode\t\t\tPřenosný mód"
#: dh.sh:29
msgid " -s --supported Update supported VMs"
msgstr "\t-s\t--supported\t\tAktualizovat podporované VM"
#: dh.sh:30
msgid " -r --ready Update ready to run VMs"
msgstr "\t-r\t--ready\t\t\tAktualizovat připravené VM"
#: dh.sh:32
msgid " -t --tui Run TUI"
msgstr "\t-t\t--tui\t\t\tSpustit terminálové uživatelské rozhranní"
#: dh.sh:33
msgid " -g --gui Run GUI"
msgstr "\t-g\t--gui\t\t\tSpustit grafické uživatelské rozhranní"
#: dh.sh:35
msgid " -a --add Add new distro to quickget"
msgstr "\t-a\t--add\t\t\tPřidat distribuci do quickget"
#: dh.sh:36
msgid " -f --functions Sort functions in quickget"
msgstr "\t-f\t--functions\t\tSeřadit funkce v quickget"
#: dh.sh:37
msgid " -p --push Push changed quickget to quickemu project #todo"
msgstr "\t-p\t--push\t\t\tPoslat změněný quickget do quickemu projektu #UDELAT"
#: dh.sh:39
msgid " -c --copy Copy all ISOs to target dir (for Ventoy)"
msgstr "\t-c\t--copy\t\t\tKopírovat všechny ISO to cílového adresáře (pro Ventoy)"
#: dh.sh:41
msgid "Homepage: dh.osowoso.xyz"
msgstr "Domovský stránka: dh.osowoso.xyz"
#: dh.sh:42
msgid "Project hosted at: https://github.com/oSoWoSo/DistroHopper"
msgstr "Projekt hostován na: https://github.com/oSoWoSo/DistroHopper"
#: dh.sh:43
msgid "Chat group on SimpleX: https://tinyurl.com/7hm4kcjx"
msgstr "Chat skupina na SimpleX: https://tinyurl.com/7hm4kcjx"
#: dh.sh:66
msgid "Missing yad!"
msgstr "Chybí vám yad!"
#: dh.sh:70
msgid "Missing fzf!"
msgstr "Chybí vám fzf!"
#: dh.sh:93
msgid "creating config dir..."
msgstr "vytvářím adresář konfigurace..."
#: dh.sh:95
msgid "creating icons dir as root..."
msgstr "vytvářím adresář ikon jako superuživatel..."
#: dh.sh:118
msgid "Copying icons..."
msgstr "Kopíruji ikony..."
#: dh.sh:120
msgid "Copying to config dir..."
msgstr "Kopíruji do konfig adresáře..."
#: dh.sh:130
msgid "Creating directory structure..."
msgstr "Vytvářím adresářovou stukturu..."
#: dh.sh:132
msgid "Setting up directory..."
msgstr "Nastavuji adresář..."
#: dh.sh:134
msgid "Installing needed..."
msgstr "Instaluji potřebné..."
#: dh.sh:135
msgid "For now voidlinux only"
msgstr "Zatím jen VoidLinux"
#: dh.sh:137
msgid "Installing DistroHopper to bin..."
msgstr "Instaluji DistroHopper do bin..."
#: dh.sh:279
msgid "No VMs found."
msgstr "Žádný VM nenalezen."
#: dh.sh:411
msgid "Which language you want use [en_US cs_CZ]?"
msgstr "Který jazyk chcete použít [en_US cs_CZ]?"
#: dh.sh:438
msgid "No argumet provided!\\n\\n"
msgstr "Nezadali jste žádný argument!\\n\\n"
#: dh.sh:456
msgid "Starting installation..."
msgstr "Zahajuji instalaci..."
#: dh.sh:461
msgid "Switching to portable mode!"
msgstr "Přepínám do přenosného módu!"
#: dh.sh:466
msgid "Updating supported VMs..."
msgstr "Aktualizuji podporované VM..."
#: dh.sh:471
msgid "Updating ready VMs..."
msgstr "Aktualizuji připravené VM..."
#: dh.sh:476
msgid "Running TUI..."
msgstr "Spouštím TUI..."
#: dh.sh:481
msgid "Starting DistroHopper GUI..."
msgstr "Spouštím DistroHopper GUI..."
#: dh.sh:486
msgid "Adding new distro started..."
msgstr "Přidání nového distra zahájeno..."
#: dh.sh:491
msgid "Sorting functions in template..."
msgstr "Srovnávám funkce v šabloně..."
#: dh.sh:496
msgid "Pushing changes to... #TODO"
msgstr "Posílám změny do... #UDELAT"
#: dh.sh:501
msgid "Copying ISOs to dir. It will take some time..."
msgstr "Kopíruji soubory ISO do adresáře. Zabere to nějaký čas..."
#: dh.sh:506
msgid "Running supported test..."
msgstr "Spouštím test podporovaných..."
#: dh.sh:515
msgid "Invalid option: $1\\n\\n"
msgstr "Chybný argument: $1\\n\\n"

147
documents/distrohopper.pot Normal file
View File

@ -0,0 +1,147 @@
#: dh.sh:10
msgid "Done"
msgstr "Hotovo"
#: dh.sh:11
msgid "PS: You saw some bugs?"
msgstr "PS: Viděli jste nějaké chyby?"
#: dh.sh:12
msgid "Could you please provide feedback?"
msgstr "Můžete prosím poslat zpětnou vazbu?"
#: dh.sh:13
msgid "How do you like DistroHopper?"
msgstr "Jak se vám líbí DistroHopper?"
#: dh.sh:14
msgid "What can be improved, added, changed?"
msgstr "Co může být vylepšeno, přidáno, změněno?"
#: dh.sh:15
msgid " Let me know..."
msgstr " Dejte mi vědět..."
#: dh.sh:16
msgid "Flawless distro hopping..."
msgstr "Bezchybné zkoušení distribucí..."
#: dh.sh:21
msgid "Possible arguments:"
msgstr "Možné argumenty:"
#: dh.sh:22
msgid " -h --help Show this help and exit"
msgstr " -h --help Zobrazit tuto nápovědu a skončit"
#: dh.sh:24
msgid " -d --dir Set default directory where VMs are stored"
msgstr " -d --dir Nastavit adresář kde jsou virtuální stroje uloženy"
#: dh.sh:25
msgid " -i --install Install DistroHopper"
msgstr "\t-i\t--install\t\tInstalovat DistroHopper"
#: dh.sh:27
msgid " -m --mode Portable mode"
msgstr "\t-m\t--mode\t\t\tPřenosný mód"
#: dh.sh:29
msgid " -s --supported Update supported VMs"
msgstr "\t-s\t--supported\t\tAktualizovat podporované VM"
#: dh.sh:30
msgid " -r --ready Update ready to run VMs"
msgstr "\t-r\t--ready\t\t\tAktualizovat připravené VM"
#: dh.sh:32
msgid " -t --tui Run TUI"
msgstr "\t-t\t--tui\t\t\tSpustit terminálové uživatelské rozhranní"
#: dh.sh:33
msgid " -g --gui Run GUI"
msgstr "\t-g\t--gui\t\t\tSpustit grafické uživatelské rozhranní"
#: dh.sh:35
msgid " -a --add Add new distro to quickget"
msgstr "\t-a\t--add\t\t\tPřidat distribuci do quickget"
#: dh.sh:36
msgid " -f --functions Sort functions in quickget"
msgstr "\t-f\t--functions\t\tSeřadit funkce v quickget"
#: dh.sh:37
msgid " -p --push Push changed quickget to quickemu project #todo"
msgstr "\t-p\t--push\t\t\tPoslat změněný quickget do quickemu projektu #UDELAT"
#: dh.sh:39
msgid " -c --copy Copy all ISOs to target dir (for Ventoy)"
msgstr "\t-c\t--copy\t\t\tKopírovat všechny ISO to cílového adresáře (pro Ventoy)"
#: dh.sh:41
msgid "Homepage: dh.osowoso.xyz"
msgstr "Domovský stránka: dh.osowoso.xyz"
#: dh.sh:42
msgid "Project hosted at: https://github.com/oSoWoSo/DistroHopper"
msgstr "Projekt hostován na: https://github.com/oSoWoSo/DistroHopper"
#: dh.sh:43
msgid "Chat group on SimpleX: https://tinyurl.com/7hm4kcjx"
msgstr "Chat skupina na SimpleX: https://tinyurl.com/7hm4kcjx"
#: dh.sh:66
msgid "Missing yad!"
msgstr "Chybí vám yad!"
#: dh.sh:70
msgid "Missing fzf!"
msgstr "Chybí vám fzf!"
#: dh.sh:93
msgid "creating config dir..."
msgstr "vytvářím adresář konfigurace..."
#: dh.sh:95
msgid "creating icons dir as root..."
msgstr "vytvářím adresář ikon jako superuživatel..."
#: dh.sh:118
msgid "Copying icons..."
msgstr "Kopíruji ikony..."
#: dh.sh:120
msgid "Copying to config dir..."
msgstr "Kopíruji do konfig adresáře..."
#: dh.sh:130
msgid "Creating directory structure..."
msgstr "Vytvářím adresářovou stukturu..."
#: dh.sh:132
msgid "Setting up directory..."
msgstr "Nastavuji adresář..."
#: dh.sh:134
msgid "Installing needed..."
msgstr "Instaluji potřebné..."
#: dh.sh:135
msgid "For now voidlinux only"
msgstr "Zatím jen VoidLinux"
#: dh.sh:137
msgid "Installing DistroHopper to bin..."
msgstr "Instaluji DistroHopper do bin..."
#: dh.sh:279
msgid "No VMs found."
msgstr "Žádný VM nenalezen."
#: dh.sh:411
msgid "Which language you want use [en_US cs_CZ]?"
msgstr "Který jazyk chcete použít [en_US cs_CZ]?"
#: dh.sh:438
msgid "No argumet provided!\\n\\n"
msgstr "Nezadali jste žádný argument!\\n\\n"
#: dh.sh:456
msgid "Starting installation..."
msgstr "Zahajuji instalaci..."
#: dh.sh:461
msgid "Switching to portable mode!"
msgstr "Přepínám do přenosného módu!"
#: dh.sh:466
msgid "Updating supported VMs..."
msgstr "Aktualizuji podporované VM..."
#: dh.sh:471
msgid "Updating ready VMs..."
msgstr "Aktualizuji připravené VM..."
#: dh.sh:476
msgid "Running TUI..."
msgstr "Spouštím TUI..."
#: dh.sh:481
msgid "Starting DistroHopper GUI..."
msgstr "Spouštím DistroHopper GUI..."
#: dh.sh:486
msgid "Adding new distro started..."
msgstr "Přidání nového distra zahájeno..."
#: dh.sh:491
msgid "Sorting functions in template..."
msgstr "Srovnávám funkce v šabloně..."
#: dh.sh:496
msgid "Pushing changes to... #TODO"
msgstr "Posílám změny do... #UDELAT"
#: dh.sh:501
msgid "Copying ISOs to dir. It will take some time..."
msgstr "Kopíruji soubory ISO do adresáře. Zabere to nějaký čas..."
#: dh.sh:506
msgid "Running supported test..."
msgstr "Spouštím test podporovaných..."
#: dh.sh:515
msgid "Invalid option: $1\\n\\n"
msgstr "Chybný argument: $1\\n\\n"

8
documents/pandoc-man.mk Normal file
View File

@ -0,0 +1,8 @@
PANDOC ?= pandoc
MANSECTION ?= 1
MANPAGE.md = $(PANDOC) --standalone $(PANDOCFLAGS) --to man
%.$(MANSECTION): %.$(MANSECTION).md
$(MANPAGE.md) $< -o $@

932
documents/quickemu.1 Normal file
View File

@ -0,0 +1,932 @@
.\" Automatically generated by Pandoc 2.19.2
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
.ie "\f[CB]x\f[]"x" \{\
. ftr V B
. ftr VI BI
. ftr VB B
. ftr VBI BI
.\}
.el \{\
. ftr V CR
. ftr VI CI
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKEMU" "1" "February 4, 2023" "quickemu" "Quickemu User Manual"
.hy
.SH NAME
.PP
quickemu - A quick VM builder and manager
.SH SYNOPSIS
.PP
\f[B]quickemu\f[R] [\f[I]OPTION\f[R]]\&...
.SH DESCRIPTION
.PP
\f[B]quickemu\f[R] will create and run highly optimised desktop virtual
machines for Linux, macOS and Windows
.SH OPTIONS
.TP
\f[B]\[en]vm\f[R]
vm configuration file
.PP
You can also pass optional parameters
.TP
\f[B]\[en]braille\f[R]
Enable braille support.
Requires SDL.
.TP
\f[B]\[en]delete\f[R]
Delete the disk image.
.TP
\f[B]\[en]display\f[R]
Select display backend.
`sdl' (default), `gtk', `none' or `spice'
.TP
\f[B]\[en]fullscreen\f[R]
Starts VM in full screen mode (Ctl+Alt+f to exit)
.TP
\f[B]\[en]ignore-msrs-always\f[R]
Configure KVM to always ignore unhandled machine-specific registers
.TP
\f[B]\[en]screen <screen>\f[R]
Use specified screen to determine the window size.
.TP
\f[B]\[en]shortcut\f[R]
Create a desktop shortcut
.TP
\f[B]\[en]snapshot apply <tag>\f[R]
Apply/restore a snapshot.
.TP
\f[B]\[en]snapshot create <tag>\f[R]
Create a snapshot.
.TP
\f[B]\[en]snapshot delete <tag>\f[R]
Delete a snapshot.
.TP
\f[B]\[en]snapshot info\f[R]
Show disk/snapshot info.
.TP
\f[B]\[en]status-quo\f[R]
Do not commit any changes to disk/snapshot.
.TP
\f[B]\[en]version\f[R]
Print version
.SH EXAMPLES
.TP
\f[B]quickemu \[en]vm ubuntu-mate-22.04.conf\f[R]
Launches the VM specified in the file \f[I]ubuntu-mate-22.04.conf\f[R]
.SS Introduction
.PP
Quickly create and run highly optimised desktop virtual machines for
Linux, macOS and Windows; with just two commands.
You decide what operating system you want to run and Quickemu will
figure out the best way to do it for you.
For example:
.IP
.nf
\f[C]
quickget ubuntu-mate 22.04
quickemu --vm ubuntu-mate-22.04.conf
\f[R]
.fi
.PP
The original objective of the project was to enable quick testing of
Linux distributions where the virtual machine configurations can be
stored anywhere, such as external USB storage or your home directory,
and no elevated permissions are required to run the virtual machines.
\f[B]Quickemu now also includes comprehensive support for macOS and
Windows\f[R].
.SS Features
.IP \[bu] 2
\f[B]macOS\f[R] Monterey, Big Sur, Catalina, Mojave & High Sierra
.IP \[bu] 2
\f[B]Windows\f[R] 8.1, 10 and 11 including TPM 2.0
.IP \[bu] 2
Ubuntu (https://ubuntu.com/desktop) and all the \f[B]official Ubuntu
flavours (https://ubuntu.com/download/flavours)\f[R]
.IP \[bu] 2
\f[B]Over 360 operating system editions are supported!\f[R]
.IP \[bu] 2
Full SPICE support including host/guest clipboard sharing
.IP \[bu] 2
VirtIO-webdavd file sharing for Linux and Windows guests
.IP \[bu] 2
VirtIO-9p file sharing for Linux and macOS guests
.IP \[bu] 2
QEMU Guest Agent support (https://wiki.qemu.org/Features/GuestAgent);
provides access to a system-level agent via standard QMP commands
.IP \[bu] 2
Samba file sharing for Linux, macOS and Windows guests (\f[I]if
\f[VI]smbd\f[I] is installed on the host\f[R])
.IP \[bu] 2
VirGL acceleration
.IP \[bu] 2
USB device pass-through
.IP \[bu] 2
Smartcard pass-through
.IP \[bu] 2
Automatic SSH port forwarding to guests
.IP \[bu] 2
Network port forwarding
.IP \[bu] 2
Full duplex audio
.IP \[bu] 2
Braille support
.IP \[bu] 2
EFI (with or without SecureBoot) and Legacy BIOS boot
.IP \[bu] 2
Graphical user interfaces available
.PP
Quickemu is a wrapper for the excellent QEMU (https://www.qemu.org/)
that attempts to automatically \f[I]\[lq]do the right thing\[rq]\f[R],
rather than expose exhaustive configuration options.
.PP
We have a Discord for this project:
[IMAGE: Discord (https://img.shields.io/discord/712850672223125565?color=0C306A&label=WimpysWorld%20Discord&logo=Discord&logoColor=ffffff&style=flat-square)] (https://discord.gg/sNmz3uw)
.PP
See this (old) video where I explain some of my motivations for creating
Quickemu.
.PP
[IMAGE: Replace VirtualBox with Bash &
QEMU (https://img.youtube.com/vi/AOTYWEgw0hI/0.jpg)] (https://www.youtube.com/watch?v=AOTYWEgw0hI)
.SS Requirements
.IP \[bu] 2
QEMU (https://www.qemu.org/) (\f[I]6.0.0 or newer\f[R]) \f[B]with GTK,
SDL, SPICE & VirtFS support\f[R]
.IP \[bu] 2
bash (https://www.gnu.org/software/bash/) (\f[I]4.0 or newer\f[R])
.IP \[bu] 2
Coreutils (https://www.gnu.org/software/coreutils/)
.IP \[bu] 2
EDK II (https://github.com/tianocore/edk2)
.IP \[bu] 2
grep (https://www.gnu.org/software/grep/)
.IP \[bu] 2
jq (https://stedolan.github.io/jq/)
.IP \[bu] 2
LSB (https://wiki.linuxfoundation.org/lsb/start)
.IP \[bu] 2
procps (https://gitlab.com/procps-ng/procps)
.IP \[bu] 2
python3 (https://www.python.org/)
.IP \[bu] 2
macrecovery (https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macrecovery)
.IP \[bu] 2
mkisofs (http://cdrtools.sourceforge.net/private/cdrecord.html)
.IP \[bu] 2
usbutils (https://github.com/gregkh/usbutils)
.IP \[bu] 2
util-linux (https://github.com/karelzak/util-linux)
.IP \[bu] 2
sed (https://www.gnu.org/software/sed/)
.IP \[bu] 2
socat (http://www.dest-unreach.org/socat/)
.IP \[bu] 2
spicy (https://gitlab.freedesktop.org/spice/spice-gtk)
.IP \[bu] 2
swtpm (https://github.com/stefanberger/swtpm)
.IP \[bu] 2
Wget (https://www.gnu.org/software/wget/)
.IP \[bu] 2
xdg-user-dirs (https://www.freedesktop.org/wiki/Software/xdg-user-dirs/)
.IP \[bu] 2
xrandr (https://gitlab.freedesktop.org/xorg/app/xrandr)
.IP \[bu] 2
zsync (http://zsync.moria.org.uk/)
.IP \[bu] 2
unzip (http://www.info-zip.org/UnZip.html)
.SS Installing Requirements
.PP
For Ubuntu, Arch and nixos systems the
ppa (https://launchpad.net/~flexiondotorg/+archive/ubuntu/quickemu),
AUR (https://aur.archlinux.org/packages/quickemu) or
nix (https://github.com/NixOS/nixpkgs/tree/master/pkgs/development/quickemu)
packaging will take care of the dependencies.
For other host distributions or operating systems it will be necessary
to install the above requirements or their equivalents.
.PP
These examples may save a little typing
.PP
Debian:
.IP
.nf
\f[C]
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip
\f[R]
.fi
.PP
Fedora:
.IP
.nf
\f[C]
sudo dnf install qemu bash coreutils edk2-tools grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-gtk-tools swtpm wget xdg-user-dirs xrandr unzip
\f[R]
.fi
.PP
MacOS:
.PP
This is a work in progress (see issue
248 (https://github.com/quickemu-project/quickemu/issues/248) for other
steps and changes that may enable running on MacOS)
.IP
.nf
\f[C]
brew install qemu bash coreutils grep jq python\[at]3.10 cdrtools gnu-sed spice-gtk wget zsync
\f[R]
.fi
.SH Usage
.SS Graphical User Interfaces
.PP
While \f[V]quickemu\f[R] and \f[V]quickget\f[R] are designed for the
terminal, a graphical user interface is also available:
.IP \[bu] 2
\f[B]Quickgui (https://github.com/quickgui/quickgui)\f[R] by Mark
Johnson (https://github.com/marxjohnson) and Yannick
Mauray (https://github.com/ymauray).
.PP
Many thanks to Luke Wesley-Holley (https://github.com/Lukewh) and
Philipp Kiemle (https://github.com/daPhipz) for creating the
\f[B]Quickemu icons (https://github.com/Lukewh/quickemu-icons)\f[R]
\[u1F3A8]
.SS Quickgui for Ubuntu
.IP
.nf
\f[C]
sudo add-apt-repository ppa:yannick-mauray/quickgui
sudo apt update
sudo apt install quickgui
\f[R]
.fi
.SS Ubuntu Guest
.PP
\f[V]quickget\f[R] will automatically download an Ubuntu release and
create the virtual machine configuration.
.IP
.nf
\f[C]
quickget ubuntu 22.04
quickemu --vm ubuntu-22.04.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as normal.
.IP \[bu] 2
Post-install:
.RS 2
.IP \[bu] 2
Install the SPICE agent (\f[V]spice-vdagent\f[R]) in the guest to enable
copy/paste and USB redirection
.RS 2
.IP \[bu] 2
\f[V]sudo apt install spice-vdagent\f[R]
.RE
.IP \[bu] 2
Install the SPICE WebDAV agent (\f[V]spice-webdavd\f[R]) in the guest to
enable file sharing.
.RS 2
.IP \[bu] 2
\f[V]sudo apt install spice-webdavd\f[R]
.RE
.RE
.SS Ubuntu devel (daily-live) images
.PP
\f[V]quickget\f[R] can also download/refresh devel images via
\f[V]zsync\f[R] for Ubuntu developers and testers.
.IP
.nf
\f[C]
quickget ubuntu devel
quickemu --vm ubuntu-devel.conf
\f[R]
.fi
.PP
You can run \f[V]quickget ubuntu devel\f[R] to refresh your daily
development image as often as you like, it will even automatically
switch to a new series.
.SS Ubuntu Flavours
.PP
All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu\f[R] with your preferred flavour.
.IP \[bu] 2
\f[V]kubuntu\f[R] (Kubuntu)
.IP \[bu] 2
\f[V]lubuntu\f[R] (Lubuntu)
.IP \[bu] 2
\f[V]ubuntu-budgie\f[R] (Ubuntu Budgie)
.IP \[bu] 2
\f[V]ubuntukylin\f[R] (Ubuntu Kylin)
.IP \[bu] 2
\f[V]ubuntu-mate\f[R] (Ubuntu MATE)
.IP \[bu] 2
\f[V]ubuntustudio\f[R] (Ubuntu Studio)
.IP \[bu] 2
\f[V]ubuntu\f[R] (Ubuntu)
.IP \[bu] 2
\f[V]ubuntu-unity\f[R] (Ubuntu Unity)
.IP \[bu] 2
\f[V]xubuntu\f[R] (Xubuntu)
.SS Other Operating Systems
.PP
\f[V]quickget\f[R] also supports:
.IP \[bu] 2
\f[V]alma\f[R] (Alma Linux)
.IP \[bu] 2
\f[V]alpine\f[R] (Alpine Linux)
.IP \[bu] 2
\f[V]android\f[R] (Android x86)
.IP \[bu] 2
\f[V]archcraft\f[R] (Archcraft)
.IP \[bu] 2
\f[V]archlinux\f[R] (Arch Linux)
.IP \[bu] 2
\f[V]arcolinux\f[R] (Arco Linux)
.IP \[bu] 2
\f[V]batocera\f[R] (Batocera)
.IP \[bu] 2
\f[V]cachyos\f[R] (CachyOS)
.IP \[bu] 2
\f[V]centos-stream\f[R] (CentOS Stream)
.IP \[bu] 2
\f[V]debian\f[R] (Debian)
.IP \[bu] 2
\f[V]deepin\f[R] (Deepin)
.IP \[bu] 2
\f[V]devuan\f[R] (Devuan)
.IP \[bu] 2
\f[V]dragonflybsd\f[R] (DragonFlyBSD)
.IP \[bu] 2
\f[V]elementary\f[R] (elementary OS)
.IP \[bu] 2
\f[V]endeavouros\f[R] (EndeavourOS)
.IP \[bu] 2
\f[V]fedora\f[R] (Fedora)
.IP \[bu] 2
\f[V]freebsd\f[R] (FreeBSD)
.IP \[bu] 2
\f[V]freedos\f[R] (FreeDOS)
.IP \[bu] 2
\f[V]garuda\f[R] (Garuda Linux)
.IP \[bu] 2
\f[V]gentoo\f[R] (Gentoo)
.IP \[bu] 2
\f[V]ghostbsd\f[R] (GhostBSD)
.IP \[bu] 2
\f[V]haiku\f[R] (Haiku)
.IP \[bu] 2
\f[V]kali\f[R] (Kali)
.IP \[bu] 2
\f[V]kdeneon\f[R] (KDE Neon)
.IP \[bu] 2
\f[V]kolibrios\f[R] (KolibriOS)
.IP \[bu] 2
\f[V]linuxmint\f[R] (Linux Mint)
.IP \[bu] 2
\f[V]lmde\f[R] (Linux Mint Debian Edition)
.IP \[bu] 2
\f[V]mageia\f[R] (Mageia)
.IP \[bu] 2
\f[V]manjaro\f[R] (Manjaro)
.IP \[bu] 2
\f[V]mxlinux\f[R] (MX Linux)
.IP \[bu] 2
\f[V]netboot\f[R] (netboot.xyz)
.IP \[bu] 2
\f[V]netbsd\f[R] (NetBSD)
.IP \[bu] 2
\f[V]nixos\f[R] (NixOS)
.IP \[bu] 2
\f[V]openbsd\f[R] (OpenBSD)
.IP \[bu] 2
\f[V]opensuse\f[R] (openSUSE)
.IP \[bu] 2
\f[V]oraclelinux\f[R] (Oracle Linux)
.IP \[bu] 2
\f[V]popos\f[R] (Pop!_OS)
.IP \[bu] 2
\f[V]reactos\f[R] (ReactOS)
.IP \[bu] 2
\f[V]rebornos\f[R] (RebornOS)
.IP \[bu] 2
\f[V]rockylinux\f[R] (Rocky Linux)
.IP \[bu] 2
\f[V]slackware\f[R] (Slackware)
.IP \[bu] 2
\f[V]solus\f[R] (Solus)
.IP \[bu] 2
\f[V]tails\f[R] (Tails)
.IP \[bu] 2
\f[V]truenas-core\f[R] (TrueNAS Core)
.IP \[bu] 2
\f[V]truenas-scale\f[R] (TrueNAS Scale)
.IP \[bu] 2
\f[V]void\f[R] (Void Linux)
.IP \[bu] 2
\f[V]zorin\f[R] (Zorin OS)
.PP
Or you can download a Linux image and manually create a VM
configuration.
.IP \[bu] 2
Download a .iso image of a Linux distribution
.IP \[bu] 2
Create a VM configuration file; for example
\f[V]debian-bullseye.conf\f[R]
.IP
.nf
\f[C]
guest_os=\[dq]linux\[dq]
disk_img=\[dq]debian-bullseye/disk.qcow2\[dq]
iso=\[dq]debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso\[dq]
\f[R]
.fi
.IP \[bu] 2
Use \f[V]quickemu\f[R] to start the virtual machine:
.IP
.nf
\f[C]
quickemu --vm debian-bullseye.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as normal.
.IP \[bu] 2
Post-install:
.RS 2
.IP \[bu] 2
Install the SPICE agent (\f[V]spice-vdagent\f[R]) in the guest to enable
copy/paste and USB redirection.
.IP \[bu] 2
Install the SPICE WebDAV agent (\f[V]spice-webdavd\f[R]) in the guest to
enable file sharing.
.RE
.SS macOS Guest
.PP
\f[V]quickget\f[R] automatically downloads a macOS recovery image and
creates a virtual machine configuration.
.IP
.nf
\f[C]
quickget macos catalina
quickemu --vm macos-catalina.conf
\f[R]
.fi
.PP
macOS \f[V]high-sierra\f[R], \f[V]mojave\f[R], \f[V]catalina\f[R],
\f[V]big-sur\f[R] and \f[V]monterey\f[R] are supported.
.IP \[bu] 2
Use cursor keys and enter key to select the \f[B]macOS Base System\f[R]
.IP \[bu] 2
From \f[B]macOS Utilities\f[R]
.RS 2
.IP \[bu] 2
Click \f[B]Disk Utility\f[R] and \f[B]Continue\f[R]
.RS 2
.IP \[bu] 2
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list and
click \f[B]Erase\f[R].
.IP \[bu] 2
Enter a \f[V]Name:\f[R] for the disk
.IP \[bu] 2
If you are installing macOS Mojave or later (Catalina, Big Sur, and
Monterey), choose any of the APFS options as the filesystem.
MacOS Extended may not work.
.RE
.IP \[bu] 2
Click \f[B]Erase\f[R].
.IP \[bu] 2
Click \f[B]Done\f[R].
.IP \[bu] 2
Close Disk Utility
.RE
.IP \[bu] 2
From \f[B]macOS Utilities\f[R]
.RS 2
.IP \[bu] 2
Click \f[B]Reinstall macOS\f[R] and \f[B]Continue\f[R]
.RE
.IP \[bu] 2
Complete the installation as you normally would.
.RS 2
.IP \[bu] 2
On the first reboot use cursor keys and enter key to select \f[B]macOS
Installer\f[R]
.IP \[bu] 2
On the subsequent reboots use cursor keys and enter key to select the
disk you named
.RE
.IP \[bu] 2
Once you have finished installing macOS you will be presented with an
the out-of-the-box first-start wizard to configure various options and
set up your username and password
.IP \[bu] 2
OPTIONAL: After you have concluded the out-of-the-box wizard, you may
want to enable the TRIM feature that the computer industry created for
SSD disks.
This feature in our macOS installation will allow QuickEmu to compact
(shrink) your macOS disk image whenever you delete files inside the
Virtual Machine.
Without this step your macOS disk image will only ever get larger and
will not shrink even when you delete lots of data inside macOS.
.RS 2
.IP \[bu] 2
To enable TRIM, open the Terminal application and type the following
command followed by pressing enter to tell macos to use the TRIM command
on the hard disk when files are deleted:
.RE
.IP
.nf
\f[C]
sudo trimforce enable
\f[R]
.fi
.PP
You will be prompted to enter your account\[cq]s password to gain the
privilege needed.
Once you\[cq]ve entered your password and pressed enter the command will
request confirmation in the form of two questions that require you to
type y (for a \[lq]yes\[rq] response) followed by enter to confirm.
If you press enter without first typing y the system will consider that
a negative response as though you said \[lq]no\[rq]:
.IP
.nf
\f[C]
IMPORTANT NOTICE: This tool force-enables TRIM for all relevant attached devices, even though such devices may not have been validated for data integrity while using TRIM. Use of this tool to enable TRIM may result in unintended data loss or data corruption. It should not be used in a commercial operating environment or with important data. Before using this tool, you should back up all of your data and regularly back up data while TRIM is enabled. This tool is provided on an \[dq]as is\[dq] basis. APPLE MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THIS TOOL OR ITS USE ALONE OR IN COMBINATION WITH YOUR DEVICES, SYSTEMS, OR SERVICES. BY USING THIS TOOL TO ENABLE TRIM, YOU AGREE THAT, TO THE EXTENT PERMITTED BY APPLICABLE LAW, USE OF THE TOOL IS AT YOUR SOLE RISK AND THAT THE ENTIRE RISK AS TO SATISFACTORY QUALITY, PERFORMANCE, ACCURACY AND EFFORT IS WITH YOU.
Are you sure you with to proceed (y/N)?
\f[R]
.fi
.PP
And a second confirmation once you\[cq]ve confirmed the previous one:
.IP
.nf
\f[C]
Your system will immediately reboot when this is complete.
Is this OK (y/N)?
\f[R]
.fi
.PP
As the last message states, your system will automatically reboot as
soon as the command completes.
.PP
The default macOS configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]macos\[dq]
img=\[dq]macos-catalina/RecoveryImage.img\[dq]
disk_img=\[dq]macos-catalina/disk.qcow2\[dq]
macos_release=\[dq]catalina\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]macos\[dq]\f[R] instructs Quickemu to optimise for
macOS.
.IP \[bu] 2
\f[V]macos_release=\[dq]catalina\[dq]\f[R] instructs Quickemu to
optimise for a particular macOS release.
.RS 2
.IP \[bu] 2
For example VirtIO Network and Memory Ballooning are available in Big
Sur and newer, but not previous releases.
.IP \[bu] 2
And VirtIO Block Media (disks) are supported/stable in Catalina and
newer.
.RE
.SS macOS compatibility
.PP
There are some considerations when running macOS via Quickemu.
.IP \[bu] 2
Supported macOS releases:
.RS 2
.IP \[bu] 2
High Sierra
.IP \[bu] 2
Mojave
.IP \[bu] 2
Catalina \f[B](Recommended)\f[R]
.IP \[bu] 2
Big Sur
.IP \[bu] 2
Monterey
.RE
.IP \[bu] 2
\f[V]quickemu\f[R] will automatically download the required
OpenCore (https://github.com/acidanthera/OpenCorePkg) bootloader and
OVMF firmware from OSX-KVM (https://github.com/kholia/OSX-KVM).
.IP \[bu] 2
Optimised by default, but no GPU acceleration is available.
.RS 2
.IP \[bu] 2
Host CPU vendor is detected and guest CPU is optimised accordingly.
.IP \[bu] 2
VirtIO Block
Media (https://www.kraxel.org/blog/2019/06/macos-qemu-guest/) is used
for the system disk where supported.
.IP \[bu] 2
VirtIO \f[V]usb-tablet\f[R] (http://philjordan.eu/osx-virt/) is used for
the mouse.
.IP \[bu] 2
VirtIO Network (\f[V]virtio-net\f[R]) is supported and enabled on macOS
Big Sur and newer but previous releases use \f[V]vmxnet3\f[R].
.IP \[bu] 2
VirtIO Memory Ballooning is supported and enabled on macOS Big Sur and
newer but disabled for other support macOS releases.
.RE
.IP \[bu] 2
USB host and SPICE pass-through is:
.RS 2
.IP \[bu] 2
UHCI (USB 2.0) on macOS Catalina and earlier.
.IP \[bu] 2
XHCI (USB 3.0) on macOS Big Sur and newer.
.RE
.IP \[bu] 2
Display resolution can only be changed via macOS System Preferences.
.IP \[bu] 2
\f[B]Full Duplex audio requires VoodooHDA
OC (https://github.com/chris1111/VoodooHDA-OC) or pass-through a USB
audio-device to the macOS guest VM\f[R].
.IP \[bu] 2
NOTE!
Gatekeeper (https://disable-gatekeeper.github.io/) and System Integrity
Protection
(SIP) (https://developer.apple.com/documentation/security/disabling_and_enabling_system_integrity_protection)
need to be disabled to install VoodooHDA OC
.IP \[bu] 2
File sharing between guest and host is available via
virtio-9p (https://wiki.qemu.org/Documentation/9psetup) and SPICE
webdavd (https://gitlab.gnome.org/GNOME/phodav/-/merge_requests/24).
.IP \[bu] 2
Copy/paste via SPICE agent is \f[B]not available on macOS\f[R].
.SS macOS App Store
.PP
If you see \f[I]\[lq]Your device or computer could not be
verified\[rq]\f[R] when you try to login to the App Store, make sure
that your wired ethernet device is \f[V]en0\f[R].
Use \f[V]ifconfig\f[R] in a terminal to verify this.
.PP
If the wired ethernet device is not \f[V]en0\f[R], then then go to
\f[I]System Preferences\f[R] -> \f[I]Network\f[R], delete all the
network devices and apply the changes.
Next, open a terminal and run the following:
.IP
.nf
\f[C]
sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
\f[R]
.fi
.PP
Now reboot, and the App Store should work.
.SS Windows 10 & 11 Guests
.PP
\f[V]quickget\f[R] can not download
Windows10 (https://www.microsoft.com/software-download/windows10) and
Windows 11 (https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
This configuration also includes the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
\f[V]quickget\f[R] can automatically download Windows 8.1, Windows
10 (https://www.microsoft.com/en-gb/software-download/windows10ISO) and
Windows 11 (https://www.microsoft.com/en-gb/software-download/windows11)
along with the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
.IP
.nf
\f[C]
quickget windows 11
quickemu --vm windows-11.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as you normally would.
.IP \[bu] 2
All relevant drivers and services should be installed automatically.
.IP \[bu] 2
A local adminstrator user account is automatically created, with these
credentials:
.RS 2
.IP \[bu] 2
Username: \f[V]Quickemu\f[R]
.IP \[bu] 2
Password: \f[V]quickemu\f[R]
.RE
.PP
The default Windows 11 configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]windows\[dq]
disk_img=\[dq]windows-11/disk.qcow2\[dq]
iso=\[dq]windows-11/windows-11.iso\[dq]
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
tpm=\[dq]on\[dq]
secureboot=\[dq]on\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]windows\[dq]\f[R] instructs \f[V]quickemu\f[R] to
optimise for Windows.
.IP \[bu] 2
\f[V]fixed_iso=\f[R] specifies the ISO image that provides VirtIO
drivers.
.IP \[bu] 2
\f[V]tpm=\[dq]on\[dq]\f[R] instructs \f[V]quickemu\f[R] to create a
software emulated TPM device using \f[V]swtpm\f[R].
.SH All the options
.PP
Here are the usage instructions:
.IP
.nf
\f[C]
Usage
quickemu --vm ubuntu.conf
You can also pass optional parameters
--braille : Enable braille support. Requires SDL.
--delete-disk : Delete the disk image and EFI variables
--delete-vm : Delete the entire VM and it\[aq]s configuration
--display : Select display backend. \[aq]sdl\[aq] (default), \[aq]gtk\[aq], \[aq]none\[aq], \[aq]spice\[aq] or \[aq]spice-app\[aq]
--fullscreen : Starts VM in full screen mode (Ctl+Alt+f to exit)
--ignore-msrs-always : Configure KVM to always ignore unhandled machine-specific registers
--screen <screen> : Use specified screen to determine the window size.
--shortcut : Create a desktop shortcut
--snapshot apply <tag> : Apply/restore a snapshot.
--snapshot create <tag> : Create a snapshot.
--snapshot delete <tag> : Delete a snapshot.
--snapshot info : Show disk/snapshot info.
--status-quo : Do not commit any changes to disk/snapshot.
--viewer <viewer> : Choose an alternative viewer. \[at]Options: \[aq]spicy\[aq] (default), \[aq]remote-viewer\[aq], \[aq]none\[aq]
--ssh-port <port> : Set ssh-port manually
--spice-port <port> : Set spice-port manually
--public-dir <path> : expose share directory. \[at]Options: \[aq]\[aq] (default: xdg-user-dir PUBLICSHARE), \[aq]<directory>\[aq], \[aq]none\[aq]
--monitor <type> : Set monitor connection type. \[at]Options: \[aq]socket\[aq] (default), \[aq]telnet\[aq], \[aq]none\[aq]
--monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: \[aq]localhost\[aq])
--monitor-telnet-port <port> : Set telnet port for monitor. (default: \[aq]4440\[aq])
--monitor-cmd <cmd> : Send command to monitor if available. (Example: system_powerdown)
--serial <type> : Set serial connection type. \[at]Options: \[aq]socket\[aq] (default), \[aq]telnet\[aq], \[aq]none\[aq]
--serial-telnet-host <ip/host> : Set telnet host for serial. (default: \[aq]localhost\[aq])
--serial-telnet-port <port> : Set telnet port for serial. (default: \[aq]6660\[aq])
--keyboard <type> : Set keyboard. \[at]Options: \[aq]usb\[aq] (default), \[aq]ps2\[aq], \[aq]virtio\[aq]
--keyboard_layout <layout> : Set keyboard layout.
--mouse <type> : Set mouse. \[at]Options: \[aq]tablet\[aq] (default), \[aq]ps2\[aq], \[aq]usb\[aq], \[aq]virtio\[aq]
--usb-controller <type> : Set usb-controller. \[at]Options: \[aq]ehci\[aq] (default), \[aq]xhci\[aq], \[aq]none\[aq]
--extra_args <arguments> : Pass additional arguments to qemu
--version : Print version
\f[R]
.fi
.SS Desktop shortcuts
.PP
Desktop shortcuts can be created for a VM, the shortcuts are saved in
\f[V]\[ti]/.local/share/applications\f[R].
Here is an example of how to create a shortcut.
.IP
.nf
\f[C]
quickemu --vm ubuntu-22.04-desktop.conf --shortcut
\f[R]
.fi
.SS Screen and window size (Linux guests only)
.PP
\f[V]qemu\f[R] will always default to the primary monitor to display the
VM\[cq]s window.
.PP
Without the \f[V]--screen\f[R] option, \f[V]quickemu\f[R] will look for
the size of the smallest monitor, and use a size that fits on said
monitor.
.PP
The \f[V]--screen\f[R] option forces \f[V]quickemu\f[R] to use the size
of the given monitor to compute the size of the window.
\f[B]It won\[cq]t use that monitor to display the VM\[cq]s window if
it\[cq]s not the primary monitor\f[R].
This is useful if the primary monitor if not the smallest one, and if
the VM\[cq]s window doesn\[cq]t need to be moved around.
.PP
The \f[V]--screen\f[R] option is also useful with the
\f[V]--fullscreen\f[R] option, again because \f[V]qemu\f[R] will always
use the primary monitor.
In order for the fullscreen mode to work properly, the resolution of the
VM\[cq]s window must match the resolution of the screen.
.PP
To know which screen to use, type:
.IP
.nf
\f[C]
xrandr --listmonitors | grep -v Monitors
\f[R]
.fi
.PP
The command will output something like this:
.IP
.nf
\f[C]
0: +*HDMI-0 2560/597x1440/336+1920+0 HDMI-0
1: +DVI-D-0 1920/527x1080/296+0+0 DVI-D-0
\f[R]
.fi
.PP
The first number is what needs to be passed to the \f[V]--screen\f[R]
option.
.PP
For example:
.IP
.nf
\f[C]
quickemu --vm vm.conf --screen 0
\f[R]
.fi
.PP
The above uses the 2560x1440 screen to compute the size of the window,
which Quickemu sizes to 2048x1152.
Without the \f[V]--screen\f[R] option, Quickemu would have used the
1920x1080 monitor which results in a window size of 1664x936.
.SH References
.PP
Useful reference that assisted the development of Quickemu.
.IP \[bu] 2
General
.RS 2
.IP \[bu] 2
QEMU\[cq]s documentation! (https://qemu.readthedocs.io/en/latest/)
.IP \[bu] 2
<https://pve.proxmox.com/wiki/Qemu/KVM_Virtual_Machines>
.IP \[bu] 2
<https://www.kraxel.org/blog/2020/01/qemu-sound-audiodev/>
.RE
.IP \[bu] 2
macOS
.RS 2
.IP \[bu] 2
<https://www.nicksherlock.com/2020/06/installing-macos-big-sur-on-proxmox/>
.IP \[bu] 2
<https://passthroughpo.st/mac-os-adds-early-support-for-virtio-qemu/>
.IP \[bu] 2
<https://github.com/kholia/OSX-KVM>
.IP \[bu] 2
<https://github.com/thenickdude/KVM-Opencore>
.IP \[bu] 2
<https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macrecovery>
.IP \[bu] 2
<https://www.kraxel.org/blog/2017/09/running-macos-as-guest-in-kvm/>
.IP \[bu] 2
<https://www.nicksherlock.com/2017/10/passthrough-of-advanced-cpu-features-for-macos-high-sierra-guests/>
.IP \[bu] 2
<http://philjordan.eu/osx-virt/>
.IP \[bu] 2
<https://github.com/Dids/clover-builder>
.IP \[bu] 2
OpenCore Configurator (https://mackie100projects.altervista.org)
.RE
.IP \[bu] 2
Windows
.RS 2
.IP \[bu] 2
<https://www.heiko-sieger.info/running-windows-10-on-linux-using-kvm-with-vga-passthrough/>
.IP \[bu] 2
<https://leduccc.medium.com/improving-the-performance-of-a-windows-10-guest-on-qemu-a5b3f54d9cf5>
.IP \[bu] 2
<https://frontpagelinux.com/tutorials/how-to-use-linux-kvm-to-optimize-your-windows-10-virtual-machine/>
.IP \[bu] 2
<https://turlucode.com/qemu-command-line-args/>
.IP \[bu] 2
<https://github.com/pbatard/Fido>
.IP \[bu] 2
<https://www.catapultsystems.com/blogs/create-zero-touch-windows-10-iso/>
.RE
.IP \[bu] 2
TPM
.RS 2
.IP \[bu] 2
<https://qemu-project.gitlab.io/qemu/specs/tpm.html>
.IP \[bu] 2
<https://www.tecklyfe.com/how-to-create-a-windows-11-virtual-machine-in-qemu/>
.RE
.IP \[bu] 2
9p & virtiofs
.RS 2
.IP \[bu] 2
<https://wiki.qemu.org/Documentation/9p>
.IP \[bu] 2
<https://wiki.qemu.org/Documentation/9psetup>
.IP \[bu] 2
<https://www.kraxel.org/blog/2019/06/macos-qemu-guest/>
.IP \[bu] 2
<https://superuser.com/questions/628169/how-to-share-a-directory-with-the-host-without-networking-in-qemu>
.IP \[bu] 2
<https://virtio-fs.gitlab.io/>
.RE
.SH AUTHORS
.PP
Written by Martin Wimpress.
.SH BUGS
.PP
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
.SH SEE ALSO
.PP
Full sources at: <https://github.com/quickemu-project/quickemu>
.PP
quickemu_conf(1), quickget(1), quickgui(1)
.SH AUTHORS
Martin Wimpress.

673
documents/quickemu.1.md Normal file
View File

@ -0,0 +1,673 @@
---
author: Martin Wimpress
date: February 4, 2023
footer: quickemu
header: Quickemu User Manual
section: 1
title: QUICKEMU
---
# NAME
quickemu - A quick VM builder and manager
# SYNOPSIS
**quickemu** \[*OPTION*\]...
# DESCRIPTION
**quickemu** will create and run highly optimised desktop virtual
machines for Linux, macOS and Windows
# OPTIONS
**--vm**
: vm configuration file
You can also pass optional parameters
**--braille**
: Enable braille support. Requires SDL.
**--delete**
: Delete the disk image.
**--display**
: Select display backend. 'sdl' (default), 'gtk', 'none' or 'spice'
**--fullscreen**
: Starts VM in full screen mode (Ctl+Alt+f to exit)
**--ignore-msrs-always**
: Configure KVM to always ignore unhandled machine-specific registers
**--screen \<screen\>**
: Use specified screen to determine the window size.
**--shortcut**
: Create a desktop shortcut
**--snapshot apply \<tag\>**
: Apply/restore a snapshot.
**--snapshot create \<tag\>**
: Create a snapshot.
**--snapshot delete \<tag\>**
: Delete a snapshot.
**--snapshot info**
: Show disk/snapshot info.
**--status-quo**
: Do not commit any changes to disk/snapshot.
**--version**
: Print version
# EXAMPLES
**quickemu --vm ubuntu-mate-22.04.conf**
: Launches the VM specified in the file *ubuntu-mate-22.04.conf*
## Introduction
Quickly create and run highly optimised desktop virtual machines for
Linux, macOS and Windows; with just two commands. You decide what
operating system you want to run and Quickemu will figure out the best
way to do it for you. For example:
``` bash
quickget ubuntu-mate 22.04
quickemu --vm ubuntu-mate-22.04.conf
```
The original objective of the project was to enable quick testing of
Linux distributions where the virtual machine configurations can be
stored anywhere, such as external USB storage or your home directory,
and no elevated permissions are required to run the virtual machines.
**Quickemu now also includes comprehensive support for macOS and
Windows**.
## Features
- **macOS** Monterey, Big Sur, Catalina, Mojave & High Sierra
- **Windows** 8.1, 10 and 11 including TPM 2.0
- [Ubuntu](https://ubuntu.com/desktop) and all the **[official Ubuntu
flavours](https://ubuntu.com/download/flavours)**
- **Over 360 operating system editions are supported!**
- Full SPICE support including host/guest clipboard sharing
- VirtIO-webdavd file sharing for Linux and Windows guests
- VirtIO-9p file sharing for Linux and macOS guests
- [QEMU Guest Agent
support](https://wiki.qemu.org/Features/GuestAgent); provides access
to a system-level agent via standard QMP commands
- Samba file sharing for Linux, macOS and Windows guests (*if `smbd`
is installed on the host*)
- VirGL acceleration
- USB device pass-through
- Smartcard pass-through
- Automatic SSH port forwarding to guests
- Network port forwarding
- Full duplex audio
- Braille support
- EFI (with or without SecureBoot) and Legacy BIOS boot
- Graphical user interfaces available
Quickemu is a wrapper for the excellent [QEMU](https://www.qemu.org/)
that attempts to automatically *"do the right thing"*, rather than
expose exhaustive configuration options.
We have a Discord for this project:
[![Discord](https://img.shields.io/discord/712850672223125565?color=0C306A&label=WimpysWorld%20Discord&logo=Discord&logoColor=ffffff&style=flat-square)](https://discord.gg/sNmz3uw)
See this (old) video where I explain some of my motivations for creating
Quickemu.
[![Replace VirtualBox with Bash &
QEMU](https://img.youtube.com/vi/AOTYWEgw0hI/0.jpg)](https://www.youtube.com/watch?v=AOTYWEgw0hI)
## Requirements
- [QEMU](https://www.qemu.org/) (*6.0.0 or newer*) **with GTK, SDL,
SPICE & VirtFS support**
- [bash](https://www.gnu.org/software/bash/) (*4.0 or newer*)
- [Coreutils](https://www.gnu.org/software/coreutils/)
- [EDK II](https://github.com/tianocore/edk2)
- [grep](https://www.gnu.org/software/grep/)
- [jq](https://stedolan.github.io/jq/)
- [LSB](https://wiki.linuxfoundation.org/lsb/start)
- [procps](https://gitlab.com/procps-ng/procps)
- [python3](https://www.python.org/)
- [macrecovery](https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macrecovery)
- [mkisofs](http://cdrtools.sourceforge.net/private/cdrecord.html)
- [usbutils](https://github.com/gregkh/usbutils)
- [util-linux](https://github.com/karelzak/util-linux)
- [sed](https://www.gnu.org/software/sed/)
- [socat](http://www.dest-unreach.org/socat/)
- [spicy](https://gitlab.freedesktop.org/spice/spice-gtk)
- [swtpm](https://github.com/stefanberger/swtpm)
- [Wget](https://www.gnu.org/software/wget/)
- [xdg-user-dirs](https://www.freedesktop.org/wiki/Software/xdg-user-dirs/)
- [xrandr](https://gitlab.freedesktop.org/xorg/app/xrandr)
- [zsync](http://zsync.moria.org.uk/)
- [unzip](http://www.info-zip.org/UnZip.html)
### Installing Requirements
For Ubuntu, Arch and nixos systems the
[ppa](https://launchpad.net/~flexiondotorg/+archive/ubuntu/quickemu),
[AUR](https://aur.archlinux.org/packages/quickemu) or
[nix](https://github.com/NixOS/nixpkgs/tree/master/pkgs/development/quickemu)
packaging will take care of the dependencies. For other host
distributions or operating systems it will be necessary to install the
above requirements or their equivalents.
These examples may save a little typing
Debian:
sudo apt install qemu bash coreutils ovmf grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-client-gtk swtpm wget xdg-user-dirs zsync unzip
Fedora:
sudo dnf install qemu bash coreutils edk2-tools grep jq lsb procps python3 genisoimage usbutils util-linux sed spice-gtk-tools swtpm wget xdg-user-dirs xrandr unzip
MacOS:
This is a work in progress (see [issue
248](https://github.com/quickemu-project/quickemu/issues/248) for other
steps and changes that may enable running on MacOS)
brew install qemu bash coreutils grep jq python@3.10 cdrtools gnu-sed spice-gtk wget zsync
# Usage
## Graphical User Interfaces
While `quickemu` and `quickget` are designed for the terminal, a
graphical user interface is also available:
- **[Quickgui](https://github.com/quickgui/quickgui)** by [Mark
Johnson](https://github.com/marxjohnson) and [Yannick
Mauray](https://github.com/ymauray).
Many thanks to [Luke Wesley-Holley](https://github.com/Lukewh) and
[Philipp Kiemle](https://github.com/daPhipz) for creating the
**[Quickemu icons](https://github.com/Lukewh/quickemu-icons)** 🎨
### Quickgui for Ubuntu
``` bash
sudo add-apt-repository ppa:yannick-mauray/quickgui
sudo apt update
sudo apt install quickgui
```
## Ubuntu Guest
`quickget` will automatically download an Ubuntu release and create the
virtual machine configuration.
``` bash
quickget ubuntu 22.04
quickemu --vm ubuntu-22.04.conf
```
- Complete the installation as normal.
- Post-install:
- Install the SPICE agent (`spice-vdagent`) in the guest to enable
copy/paste and USB redirection
- `sudo apt install spice-vdagent`
- Install the SPICE WebDAV agent (`spice-webdavd`) in the guest to
enable file sharing.
- `sudo apt install spice-webdavd`
### Ubuntu devel (daily-live) images
`quickget` can also download/refresh devel images via `zsync` for Ubuntu
developers and testers.
``` bash
quickget ubuntu devel
quickemu --vm ubuntu-devel.conf
```
You can run `quickget ubuntu devel` to refresh your daily development
image as often as you like, it will even automatically switch to a new
series.
### Ubuntu Flavours
All the official Ubuntu flavours are supported, just replace `ubuntu`
with your preferred flavour.
- `kubuntu` (Kubuntu)
- `lubuntu` (Lubuntu)
- `ubuntu-budgie` (Ubuntu Budgie)
- `ubuntukylin` (Ubuntu Kylin)
- `ubuntu-mate` (Ubuntu MATE)
- `ubuntustudio` (Ubuntu Studio)
- `ubuntu` (Ubuntu)
- `ubuntu-unity` (Ubuntu Unity)
- `xubuntu` (Xubuntu)
## Other Operating Systems
`quickget` also supports:
- `alma` (Alma Linux)
- `alpine` (Alpine Linux)
- `android` (Android x86)
- `archcraft` (Archcraft)
- `archlinux` (Arch Linux)
- `arcolinux` (Arco Linux)
- `batocera` (Batocera)
- `cachyos` (CachyOS)
- `centos-stream` (CentOS Stream)
- `debian` (Debian)
- `deepin` (Deepin)
- `devuan` (Devuan)
- `dragonflybsd` (DragonFlyBSD)
- `elementary` (elementary OS)
- `endeavouros` (EndeavourOS)
- `fedora` (Fedora)
- `freebsd` (FreeBSD)
- `freedos` (FreeDOS)
- `garuda` (Garuda Linux)
- `gentoo` (Gentoo)
- `ghostbsd` (GhostBSD)
- `haiku` (Haiku)
- `kali` (Kali)
- `kdeneon` (KDE Neon)
- `kolibrios` (KolibriOS)
- `linuxmint` (Linux Mint)
- `lmde` (Linux Mint Debian Edition)
- `mageia` (Mageia)
- `manjaro` (Manjaro)
- `mxlinux` (MX Linux)
- `netboot` (netboot.xyz)
- `netbsd` (NetBSD)
- `nixos` (NixOS)
- `openbsd` (OpenBSD)
- `opensuse` (openSUSE)
- `oraclelinux` (Oracle Linux)
- `popos` (Pop!\_OS)
- `reactos` (ReactOS)
- `rebornos` (RebornOS)
- `rockylinux` (Rocky Linux)
- `slackware` (Slackware)
- `solus` (Solus)
- `tails` (Tails)
- `truenas-core` (TrueNAS Core)
- `truenas-scale` (TrueNAS Scale)
- `void` (Void Linux)
- `zorin` (Zorin OS)
Or you can download a Linux image and manually create a VM
configuration.
- Download a .iso image of a Linux distribution
- Create a VM configuration file; for example `debian-bullseye.conf`
``` bash
guest_os="linux"
disk_img="debian-bullseye/disk.qcow2"
iso="debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso"
```
- Use `quickemu` to start the virtual machine:
``` bash
quickemu --vm debian-bullseye.conf
```
- Complete the installation as normal.
- Post-install:
- Install the SPICE agent (`spice-vdagent`) in the guest to enable
copy/paste and USB redirection.
- Install the SPICE WebDAV agent (`spice-webdavd`) in the guest to
enable file sharing.
## macOS Guest
`quickget` automatically downloads a macOS recovery image and creates a
virtual machine configuration.
``` bash
quickget macos catalina
quickemu --vm macos-catalina.conf
```
macOS `high-sierra`, `mojave`, `catalina`, `big-sur` and `monterey` are
supported.
- Use cursor keys and enter key to select the **macOS Base System**
- From **macOS Utilities**
- Click **Disk Utility** and **Continue**
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list and
click **Erase**.
- Enter a `Name:` for the disk
- If you are installing macOS Mojave or later (Catalina, Big
Sur, and Monterey), choose any of the APFS options as the
filesystem. MacOS Extended may not work.
- Click **Erase**.
- Click **Done**.
- Close Disk Utility
- From **macOS Utilities**
- Click **Reinstall macOS** and **Continue**
- Complete the installation as you normally would.
- On the first reboot use cursor keys and enter key to select
**macOS Installer**
- On the subsequent reboots use cursor keys and enter key to
select the disk you named
- Once you have finished installing macOS you will be presented with
an the out-of-the-box first-start wizard to configure various
options and set up your username and password
- OPTIONAL: After you have concluded the out-of-the-box wizard, you
may want to enable the TRIM feature that the computer industry
created for SSD disks. This feature in our macOS installation will
allow QuickEmu to compact (shrink) your macOS disk image whenever
you delete files inside the Virtual Machine. Without this step your
macOS disk image will only ever get larger and will not shrink even
when you delete lots of data inside macOS.
- To enable TRIM, open the Terminal application and type the
following command followed by pressing
`<kbd>`{=html}enter`</kbd>`{=html} to tell macos to use the TRIM
command on the hard disk when files are deleted:
``` bash
sudo trimforce enable
```
You will be prompted to enter your account's password to gain the
privilege needed. Once you've entered your password and pressed
`<kbd>`{=html}enter`</kbd>`{=html} the command will request confirmation
in the form of two questions that require you to type
`<kbd>`{=html}y`</kbd>`{=html} (for a "yes" response) followed by
`<kbd>`{=html}enter`</kbd>`{=html} to confirm. If you press
`<kbd>`{=html}enter`</kbd>`{=html} without first typing
`<kbd>`{=html}y`</kbd>`{=html} the system will consider that a negative
response as though you said "no":
``` plain
IMPORTANT NOTICE: This tool force-enables TRIM for all relevant attached devices, even though such devices may not have been validated for data integrity while using TRIM. Use of this tool to enable TRIM may result in unintended data loss or data corruption. It should not be used in a commercial operating environment or with important data. Before using this tool, you should back up all of your data and regularly back up data while TRIM is enabled. This tool is provided on an "as is" basis. APPLE MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THIS TOOL OR ITS USE ALONE OR IN COMBINATION WITH YOUR DEVICES, SYSTEMS, OR SERVICES. BY USING THIS TOOL TO ENABLE TRIM, YOU AGREE THAT, TO THE EXTENT PERMITTED BY APPLICABLE LAW, USE OF THE TOOL IS AT YOUR SOLE RISK AND THAT THE ENTIRE RISK AS TO SATISFACTORY QUALITY, PERFORMANCE, ACCURACY AND EFFORT IS WITH YOU.
Are you sure you with to proceed (y/N)?
```
And a second confirmation once you've confirmed the previous one:
``` plain
Your system will immediately reboot when this is complete.
Is this OK (y/N)?
```
As the last message states, your system will automatically reboot as
soon as the command completes.
The default macOS configuration looks like this:
``` bash
guest_os="macos"
img="macos-catalina/RecoveryImage.img"
disk_img="macos-catalina/disk.qcow2"
macos_release="catalina"
```
- `guest_os="macos"` instructs Quickemu to optimise for macOS.
- `macos_release="catalina"` instructs Quickemu to optimise for a
particular macOS release.
- For example VirtIO Network and Memory Ballooning are available
in Big Sur and newer, but not previous releases.
- And VirtIO Block Media (disks) are supported/stable in Catalina
and newer.
### macOS compatibility
There are some considerations when running macOS via Quickemu.
- Supported macOS releases:
- High Sierra
- Mojave
- Catalina **(Recommended)**
- Big Sur
- Monterey
- `quickemu` will automatically download the required
[OpenCore](https://github.com/acidanthera/OpenCorePkg) bootloader
and OVMF firmware from [OSX-KVM](https://github.com/kholia/OSX-KVM).
- Optimised by default, but no GPU acceleration is available.
- Host CPU vendor is detected and guest CPU is optimised
accordingly.
- [VirtIO Block
Media](https://www.kraxel.org/blog/2019/06/macos-qemu-guest/) is
used for the system disk where supported.
- [VirtIO `usb-tablet`](http://philjordan.eu/osx-virt/) is used
for the mouse.
- VirtIO Network (`virtio-net`) is supported and enabled on macOS
Big Sur and newer but previous releases use `vmxnet3`.
- VirtIO Memory Ballooning is supported and enabled on macOS Big
Sur and newer but disabled for other support macOS releases.
- USB host and SPICE pass-through is:
- UHCI (USB 2.0) on macOS Catalina and earlier.
- XHCI (USB 3.0) on macOS Big Sur and newer.
- Display resolution can only be changed via macOS System Preferences.
- **Full Duplex audio requires [VoodooHDA
OC](https://github.com/chris1111/VoodooHDA-OC) or pass-through a USB
audio-device to the macOS guest VM**.
- NOTE! [Gatekeeper](https://disable-gatekeeper.github.io/) and
[System Integrity Protection
(SIP)](https://developer.apple.com/documentation/security/disabling_and_enabling_system_integrity_protection)
need to be disabled to install VoodooHDA OC
- File sharing between guest and host is available via
[virtio-9p](https://wiki.qemu.org/Documentation/9psetup) and [SPICE
webdavd](https://gitlab.gnome.org/GNOME/phodav/-/merge_requests/24).
- Copy/paste via SPICE agent is **not available on macOS**.
### macOS App Store
If you see *"Your device or computer could not be verified"* when you
try to login to the App Store, make sure that your wired ethernet device
is `en0`. Use `ifconfig` in a terminal to verify this.
If the wired ethernet device is not `en0`, then then go to *System
Preferences* -\> *Network*, delete all the network devices and apply the
changes. Next, open a terminal and run the following:
``` bash
sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
```
Now reboot, and the App Store should work.
## Windows 10 & 11 Guests
`quickget` can not download
[Windows10](https://www.microsoft.com/software-download/windows10) and
[Windows 11](https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
This configuration also includes the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
`quickget` can automatically download Windows 8.1, [Windows
10](https://www.microsoft.com/en-gb/software-download/windows10ISO) and
[Windows
11](https://www.microsoft.com/en-gb/software-download/windows11) along
with the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
``` bash
quickget windows 11
quickemu --vm windows-11.conf
```
- Complete the installation as you normally would.
- All relevant drivers and services should be installed automatically.
- A local adminstrator user account is automatically created, with
these credentials:
- Username: `Quickemu`
- Password: `quickemu`
The default Windows 11 configuration looks like this:
``` bash
guest_os="windows"
disk_img="windows-11/disk.qcow2"
iso="windows-11/windows-11.iso"
fixed_iso="windows-11/virtio-win.iso"
tpm="on"
secureboot="on"
```
- `guest_os="windows"` instructs `quickemu` to optimise for Windows.
- `fixed_iso=` specifies the ISO image that provides VirtIO drivers.
- `tpm="on"` instructs `quickemu` to create a software emulated TPM
device using `swtpm`.
# All the options
Here are the usage instructions:
Usage
quickemu --vm ubuntu.conf
You can also pass optional parameters
--braille : Enable braille support. Requires SDL.
--delete-disk : Delete the disk image and EFI variables
--delete-vm : Delete the entire VM and it's configuration
--display : Select display backend. 'sdl' (default), 'gtk', 'none', 'spice' or 'spice-app'
--fullscreen : Starts VM in full screen mode (Ctl+Alt+f to exit)
--ignore-msrs-always : Configure KVM to always ignore unhandled machine-specific registers
--screen <screen> : Use specified screen to determine the window size.
--shortcut : Create a desktop shortcut
--snapshot apply <tag> : Apply/restore a snapshot.
--snapshot create <tag> : Create a snapshot.
--snapshot delete <tag> : Delete a snapshot.
--snapshot info : Show disk/snapshot info.
--status-quo : Do not commit any changes to disk/snapshot.
--viewer <viewer> : Choose an alternative viewer. @Options: 'spicy' (default), 'remote-viewer', 'none'
--ssh-port <port> : Set ssh-port manually
--spice-port <port> : Set spice-port manually
--public-dir <path> : expose share directory. @Options: '' (default: xdg-user-dir PUBLICSHARE), '<directory>', 'none'
--monitor <type> : Set monitor connection type. @Options: 'socket' (default), 'telnet', 'none'
--monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: 'localhost')
--monitor-telnet-port <port> : Set telnet port for monitor. (default: '4440')
--monitor-cmd <cmd> : Send command to monitor if available. (Example: system_powerdown)
--serial <type> : Set serial connection type. @Options: 'socket' (default), 'telnet', 'none'
--serial-telnet-host <ip/host> : Set telnet host for serial. (default: 'localhost')
--serial-telnet-port <port> : Set telnet port for serial. (default: '6660')
--keyboard <type> : Set keyboard. @Options: 'usb' (default), 'ps2', 'virtio'
--keyboard_layout <layout> : Set keyboard layout.
--mouse <type> : Set mouse. @Options: 'tablet' (default), 'ps2', 'usb', 'virtio'
--usb-controller <type> : Set usb-controller. @Options: 'ehci' (default), 'xhci', 'none'
--extra_args <arguments> : Pass additional arguments to qemu
--version : Print version
## Desktop shortcuts
Desktop shortcuts can be created for a VM, the shortcuts are saved in
`~/.local/share/applications`. Here is an example of how to create a
shortcut.
``` bash
quickemu --vm ubuntu-22.04-desktop.conf --shortcut
```
## Screen and window size (Linux guests only)
`qemu` will always default to the primary monitor to display the VM's
window.
Without the `--screen` option, `quickemu` will look for the size of the
smallest monitor, and use a size that fits on said monitor.
The `--screen` option forces `quickemu` to use the size of the given
monitor to compute the size of the window. **It won't use that monitor
to display the VM's window if it's not the primary monitor**. This is
useful if the primary monitor if not the smallest one, and if the VM's
window doesn't need to be moved around.
The `--screen` option is also useful with the `--fullscreen` option,
again because `qemu` will always use the primary monitor. In order for
the fullscreen mode to work properly, the resolution of the VM's window
must match the resolution of the screen.
To know which screen to use, type:
``` bash
xrandr --listmonitors | grep -v Monitors
```
The command will output something like this:
``` bash
0: +*HDMI-0 2560/597x1440/336+1920+0 HDMI-0
1: +DVI-D-0 1920/527x1080/296+0+0 DVI-D-0
```
The first number is what needs to be passed to the `--screen` option.
For example:
``` bash
quickemu --vm vm.conf --screen 0
```
The above uses the 2560x1440 screen to compute the size of the window,
which Quickemu sizes to 2048x1152. Without the `--screen` option,
Quickemu would have used the 1920x1080 monitor which results in a window
size of 1664x936.
# References
Useful reference that assisted the development of Quickemu.
- General
- [QEMU's documentation!](https://qemu.readthedocs.io/en/latest/)
- <https://pve.proxmox.com/wiki/Qemu/KVM_Virtual_Machines>
- <https://www.kraxel.org/blog/2020/01/qemu-sound-audiodev/>
- macOS
- <https://www.nicksherlock.com/2020/06/installing-macos-big-sur-on-proxmox/>
- <https://passthroughpo.st/mac-os-adds-early-support-for-virtio-qemu/>
- <https://github.com/kholia/OSX-KVM>
- <https://github.com/thenickdude/KVM-Opencore>
- <https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macrecovery>
- <https://www.kraxel.org/blog/2017/09/running-macos-as-guest-in-kvm/>
- <https://www.nicksherlock.com/2017/10/passthrough-of-advanced-cpu-features-for-macos-high-sierra-guests/>
- <http://philjordan.eu/osx-virt/>
- <https://github.com/Dids/clover-builder>
- [OpenCore
Configurator](https://mackie100projects.altervista.org)
- Windows
- <https://www.heiko-sieger.info/running-windows-10-on-linux-using-kvm-with-vga-passthrough/>
- <https://leduccc.medium.com/improving-the-performance-of-a-windows-10-guest-on-qemu-a5b3f54d9cf5>
- <https://frontpagelinux.com/tutorials/how-to-use-linux-kvm-to-optimize-your-windows-10-virtual-machine/>
- <https://turlucode.com/qemu-command-line-args/>
- <https://github.com/pbatard/Fido>
- <https://www.catapultsystems.com/blogs/create-zero-touch-windows-10-iso/>
- TPM
- <https://qemu-project.gitlab.io/qemu/specs/tpm.html>
- <https://www.tecklyfe.com/how-to-create-a-windows-11-virtual-machine-in-qemu/>
- 9p & virtiofs
- <https://wiki.qemu.org/Documentation/9p>
- <https://wiki.qemu.org/Documentation/9psetup>
- <https://www.kraxel.org/blog/2019/06/macos-qemu-guest/>
- <https://superuser.com/questions/628169/how-to-share-a-directory-with-the-host-without-networking-in-qemu>
- <https://virtio-fs.gitlab.io/>
# AUTHORS
Written by Martin Wimpress.
# BUGS
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
# SEE ALSO
Full sources at: <https://github.com/quickemu-project/quickemu>
quickemu_conf(1), quickget(1), quickgui(1)

327
documents/quickemu_conf.1 Normal file
View File

@ -0,0 +1,327 @@
.\" Automatically generated by Pandoc 2.19.2
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
.ie "\f[CB]x\f[]"x" \{\
. ftr V B
. ftr VI BI
. ftr VB B
. ftr VBI BI
.\}
.el \{\
. ftr V CR
. ftr VI CI
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKEMU_CONF" "1" "February 4, 2023" "quickemu_conf" "Quickemu Configuration Manual"
.hy
.SH NAME
.PP
quickemu_conf - Options and parameters in the quickemu <vm>.conf
.SH DESCRIPTION
.PP
\f[B]quickemu\f[R] will create and run highly optimised desktop virtual
machines for Linux, macOS and Windows.
It uses sensible defaults, but many configuration options can be
overridden in the required configuration file, which will as a minimum
specify the path to the installation ISO and QEMU disk for the installed
VM
.SH OPTIONS
.PP
These are the options and defaults for the <vm>.conf file
.IP
.nf
\f[C]
# Lowercase variables are used in the VM config file only
boot=\[dq]efi\[dq]
cpu_cores=\[dq]\[dq]
disk_img=\[dq]\[dq]
disk_size=\[dq]\[dq]
display=\[dq]\[dq]
extra_args=\[dq]\[dq]
fixed_iso=\[dq]\[dq]
floppy=\[dq]\[dq]
guest_os=\[dq]linux\[dq]
img=\[dq]\[dq]
iso=\[dq]\[dq]
macaddr=\[dq]\[dq]
macos_release=\[dq]\[dq]
network=\[dq]\[dq]
port_forwards=()
preallocation=\[dq]off\[dq]
ram=\[dq]\[dq]
secureboot=\[dq]off\[dq]
tpm=\[dq]off\[dq]
usb_devices=()
viewer=\[dq]spicy\[dq]
ssh_port=\[dq]\[dq]
spice_port=\[dq]\[dq]
public_dir=\[dq]\[dq]
monitor=\[dq]socket\[dq]
monitor_telnet_port=\[dq]4440\[dq]
monitor_telnet_host=\[dq]localhost\[dq]
monitor_cmd=\[dq]\[dq]
serial=\[dq]socket\[dq]
serial_telnet_port=\[dq]6660\[dq]
serial_telnet_host=\[dq]localhost\[dq]
# options: ehci(USB2.0), xhci(USB3.0)
usb_controller=\[dq]ehci\[dq]
# options: ps2, usb, virtio
keyboard=\[dq]usb\[dq]
keyboard_layout=\[dq]en-us\[dq]
# options: ps2, usb, tablet, virtio
mouse=\[dq]tablet\[dq]
\f[R]
.fi
.SH EXAMPLES
.IP
.nf
\f[C]
guest_os=\[dq]linux\[dq]
disk_img=\[dq]debian-bullseye/disk.qcow2\[dq]
iso=\[dq]debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso\[dq]
\f[R]
.fi
.PP
The default macOS configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]macos\[dq]
img=\[dq]macos-catalina/RecoveryImage.img\[dq]
disk_img=\[dq]macos-catalina/disk.qcow2\[dq]
macos_release=\[dq]catalina\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]macos\[dq]\f[R] instructs Quickemu to optimise for
macOS.
.IP \[bu] 2
\f[V]macos_release=\[dq]catalina\[dq]\f[R] instructs Quickemu to
optimise for a particular macOS release.
.RS 2
.IP \[bu] 2
For example VirtIO Network and Memory Ballooning are available in Big
Sur and newer, but not previous releases.
.IP \[bu] 2
And VirtIO Block Media (disks) are supported/stable in Catalina and
newer.
.RE
.PP
The default Windows 11 configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]windows\[dq]
disk_img=\[dq]windows-11/disk.qcow2\[dq]
iso=\[dq]windows-11/Win11_EnglishInternational_x64.iso\[dq]
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
tpm=\[dq]on\[dq]
secureboot=\[dq]on\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]windows\[dq]\f[R] instructs \f[V]quickemu\f[R] to
optimise for Windows.
.IP \[bu] 2
\f[V]fixed_iso=\f[R] specifies the ISO image that provides VirtIO
drivers.
.IP \[bu] 2
\f[V]tpm=\[dq]on\[dq]\f[R] instructs \f[V]quickemu\f[R] to create a
software emulated TPM device using \f[V]swtpm\f[R].
.SH BIOS and EFI
.PP
Since Quickemu 2.1.0 \f[V]efi\f[R] is the default boot option.
If you want to override this behaviour then add the following line to
you VM configuration to enable legacy BIOS.
.IP \[bu] 2
\f[V]boot=\[dq]legacy\[dq]\f[R] - Enable Legacy BIOS boot
.SH Tuning CPU cores, RAM & disks
.PP
By default, Quickemu will calculate the number of CPUs cores and RAM to
allocate to a VM based on the specifications of your host computer.
You can override this default behaviour and tune the VM configuration to
your liking.
.PP
Add additional lines to your virtual machine configuration:
.IP \[bu] 2
\f[V]cpu_cores=\[dq]4\[dq]\f[R] - Specify the number of CPU cores
allocated to the VM
.IP \[bu] 2
\f[V]ram=\[dq]4G\[dq]\f[R] - Specify the amount of RAM to allocate to
the VM
.IP \[bu] 2
\f[V]disk_size=\[dq]16G\[dq]\f[R] - Specify the size of the virtual disk
allocated to the VM
.SS Disk preallocation
.PP
Preallocation mode (allowed values: \f[V]off\f[R] (default),
\f[V]metadata\f[R], \f[V]falloc\f[R], \f[V]full\f[R]).
An image with preallocated metadata is initially larger but can improve
performance when the image needs to grow.
.PP
Specify what disk preallocation should be used, if any, when creating
the system disk image by adding a line like this to your VM
configuration.
.IP \[bu] 2
\f[V]preallocation=\[dq]metadata\[dq]\f[R]
.SS CD-ROM disks
.PP
If you want to expose an ISO image from the host to guest add the
following line to the VM configuration:
.IP \[bu] 2
\f[V]fixed_iso=\[dq]/path/to/image.iso\[dq]\f[R]
.SS Floppy disks
.PP
If you\[cq]re like Alan Pope (https://popey.com) you\[cq]ll probably
want to mount a floppy disk image in the guest.
To do so add the following line to the VM configuration:
.IP \[bu] 2
\f[V]floppy=\[dq]/path/to/floppy.img\[dq]\f[R]
.SH File Sharing
.PP
All File Sharing options will only expose \f[V]\[ti]/Public\f[R] (or
localised variations) for the current user to the guest VMs.
.SS Samba \[u1F427] \[u1F34F] \[u1FA9F]
.PP
If \f[V]smbd\f[R] is available on the host, Quickemu will automatically
enable the built-in QEMU support for exposing a Samba share from the
host to the guest.
.PP
You can install the minimal Samba components on Ubuntu using:
.IP
.nf
\f[C]
sudo apt install --no-install-recommends samba
\f[R]
.fi
.PP
If everything is set up correctly, the \f[V]smbd\f[R] address will be
printed when the virtual machine is started.
For example:
.IP
.nf
\f[C]
- smbd: On guest: smb://10.0.2.4/qemu
\f[R]
.fi
.PP
If using a Windows guest, right-click on \[lq]This PC\[rq], click
\[lq]Add a network location\[rq], and paste this address, removing
\f[V]smb:\f[R] and replacing forward slashes with backslashes (in this
example \f[V]\[rs]\[rs]10.0.2.4\[rs]qemu\f[R]).
.SS SPICE WebDAV \[u1F427] \[u1FA9F]
.IP \[bu] 2
TBD
.SS VirtIO-9P \[u1F427] \[u1F34F]
.IP \[bu] 2
TBD
.SH Network port forwarding
.PP
Add an additional line to your virtual machine configuration.
For example:
.IP \[bu] 2
\f[V]port_forwards=(\[dq]8123:8123\[dq] \[dq]8888:80\[dq])\f[R]
.PP
In the example above:
.IP \[bu] 2
Port 8123 on the host is forwarded to port 8123 on the guest.
.IP \[bu] 2
Port 8888 on the host is forwarded to port 80 on the guest.
.SH Disable networking
.PP
To completely disable all network interfaces in a guest VM add this
additional line to your virtual machine configuration:
.IP \[bu] 2
\f[V]network=\[dq]none\[dq]\f[R]
.SH Restricted networking
.PP
You can isolate the guest from the host (and broader network) using the
restrict option, which will restrict networking to just the guest and
any virtual devices.
.PP
This can be used to prevent software running inside the guest from
phoning home while still providing a network inside the guest.
Add this additional line to your virtual machine configuration:
.IP \[bu] 2
\f[V]network=\[dq]restrict\[dq]\f[R]
.SH Bridged networking
.PP
Connect your virtual machine to a preconfigured network bridge.
Add an additional line to your virtual machine configuration:
.IP \[bu] 2
\f[V]network=\[dq]br0\[dq]\f[R]
.PP
If you want to have a persistent MAC address for your bridged network
interface in the guest VM you can add \f[V]macaddr\f[R] to the virtual
machine configuration.
QEMU requires that the MAC address is in the range:
\f[B]52:54:00:AB:00:00 - 52:54:00:AB:FF:FF\f[R]
.PP
So you can generate your own MAC addresses with:
.IP \[bu] 2
\f[V]macaddr=\[dq]52:54:00:AB:51:AE\[dq]\f[R]
.SH USB redirection
.PP
Quickemu supports USB redirection via SPICE pass-through and host
pass-through.
.SS SPICE redirection (recommended)
.PP
Using SPICE for USB pass-through is easiest as it doesn\[cq]t require
any elevated permission, start Quickemu with \f[V]--display spice\f[R]
and then select \f[V]Input\f[R] ->
\f[V]Select USB Device for redirection\f[R] from the menu to choose
which device(s) you want to attach to the guest.
.SS Host redirection \f[B]NOT Recommended\f[R]
.PP
\f[B]USB host redirection is not recommended\f[R], it is provided purely
for backwards compatibility to older versions of Quickemu.
Using SPICE is preferred, see above.
.PP
Add an additional line to your virtual machine configuration.
For example:
.IP \[bu] 2
\f[V]usb_devices=(\[dq]046d:082d\[dq] \[dq]046d:085e\[dq])\f[R]
.PP
In the example above:
.IP \[bu] 2
The USB device with vendor_id 046d and product_id 082d will be exposed
to the guest.
.IP \[bu] 2
The USB device with vendor_id 046d and product_id 085e will be exposed
to the guest.
.PP
If the USB devices are not writable, \f[V]quickemu\f[R] will display the
appropriate commands to modify the USB device(s) access permissions,
like this:
.IP
.nf
\f[C]
- USB: Host pass-through requested:
- Sennheiser Communications EPOS GTW 270 on bus 001 device 005 needs permission changes:
sudo chown -v root:user /dev/bus/usb/001/005
ERROR! USB permission changes are required \[u1F446]
\f[R]
.fi
.SH TPM
.PP
Since Quickemu 2.2.0 a software emulated TPM device can be added to
guest virtual machines.
Just add \f[V]tpm=\[dq]on\[dq]\f[R] to your VM configuration.
\f[V]quickget\f[R] will automatically add this line to Windows 11
virtual machines.
.SH AUTHORS
.PP
Written by Martin Wimpress.
.SH BUGS
.PP
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
.SH SEE ALSO
.PP
Full sources at: <https://github.com/quickemu-project/quickemu>
.PP
quickget(1), quickemu(1), quickgui(1)
.SH AUTHORS
Martin Wimpress.

View File

@ -0,0 +1,299 @@
---
author: Martin Wimpress
date: February 4, 2023
footer: quickemu_conf
header: Quickemu Configuration Manual
section: 1
title: QUICKEMU_CONF
---
# NAME
quickemu_conf - Options and parameters in the quickemu \<vm\>.conf
# DESCRIPTION
**quickemu** will create and run highly optimised desktop virtual
machines for Linux, macOS and Windows. It uses sensible defaults, but
many configuration options can be overridden in the required
configuration file, which will as a minimum specify the path to the
installation ISO and QEMU disk for the installed VM
# OPTIONS
These are the options and defaults for the \<vm\>.conf file
``` bash
# Lowercase variables are used in the VM config file only
boot="efi"
cpu_cores=""
disk_img=""
disk_size=""
display=""
extra_args=""
fixed_iso=""
floppy=""
guest_os="linux"
img=""
iso=""
macaddr=""
macos_release=""
network=""
port_forwards=()
preallocation="off"
ram=""
secureboot="off"
tpm="off"
usb_devices=()
viewer="spicy"
ssh_port=""
spice_port=""
public_dir=""
monitor="socket"
monitor_telnet_port="4440"
monitor_telnet_host="localhost"
monitor_cmd=""
serial="socket"
serial_telnet_port="6660"
serial_telnet_host="localhost"
# options: ehci(USB2.0), xhci(USB3.0)
usb_controller="ehci"
# options: ps2, usb, virtio
keyboard="usb"
keyboard_layout="en-us"
# options: ps2, usb, tablet, virtio
mouse="tablet"
```
# EXAMPLES
``` bash
guest_os="linux"
disk_img="debian-bullseye/disk.qcow2"
iso="debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso"
```
The default macOS configuration looks like this:
``` bash
guest_os="macos"
img="macos-catalina/RecoveryImage.img"
disk_img="macos-catalina/disk.qcow2"
macos_release="catalina"
```
- `guest_os="macos"` instructs Quickemu to optimise for macOS.
- `macos_release="catalina"` instructs Quickemu to optimise for a
particular macOS release.
- For example VirtIO Network and Memory Ballooning are available
in Big Sur and newer, but not previous releases.
- And VirtIO Block Media (disks) are supported/stable in Catalina
and newer.
The default Windows 11 configuration looks like this:
``` bash
guest_os="windows"
disk_img="windows-11/disk.qcow2"
iso="windows-11/Win11_EnglishInternational_x64.iso"
fixed_iso="windows-11/virtio-win.iso"
tpm="on"
secureboot="on"
```
- `guest_os="windows"` instructs `quickemu` to optimise for Windows.
- `fixed_iso=` specifies the ISO image that provides VirtIO drivers.
- `tpm="on"` instructs `quickemu` to create a software emulated TPM
device using `swtpm`.
# BIOS and EFI
Since Quickemu 2.1.0 `efi` is the default boot option. If you want to
override this behaviour then add the following line to you VM
configuration to enable legacy BIOS.
- `boot="legacy"` - Enable Legacy BIOS boot
# Tuning CPU cores, RAM & disks
By default, Quickemu will calculate the number of CPUs cores and RAM to
allocate to a VM based on the specifications of your host computer. You
can override this default behaviour and tune the VM configuration to
your liking.
Add additional lines to your virtual machine configuration:
- `cpu_cores="4"` - Specify the number of CPU cores allocated to the
VM
- `ram="4G"` - Specify the amount of RAM to allocate to the VM
- `disk_size="16G"` - Specify the size of the virtual disk allocated
to the VM
## Disk preallocation
Preallocation mode (allowed values: `off` (default), `metadata`,
`falloc`, `full`). An image with preallocated metadata is initially
larger but can improve performance when the image needs to grow.
Specify what disk preallocation should be used, if any, when creating
the system disk image by adding a line like this to your VM
configuration.
- `preallocation="metadata"`
## CD-ROM disks
If you want to expose an ISO image from the host to guest add the
following line to the VM configuration:
- `fixed_iso="/path/to/image.iso"`
## Floppy disks
If you're like [Alan Pope](https://popey.com) you'll probably want to
mount a floppy disk image in the guest. To do so add the following line
to the VM configuration:
- `floppy="/path/to/floppy.img"`
# File Sharing
All File Sharing options will only expose `~/Public` (or localised
variations) for the current user to the guest VMs.
## Samba 🐧 🍏 🪟
If `smbd` is available on the host, Quickemu will automatically enable
the built-in QEMU support for exposing a Samba share from the host to
the guest.
You can install the minimal Samba components on Ubuntu using:
``` bash
sudo apt install --no-install-recommends samba
```
If everything is set up correctly, the `smbd` address will be printed
when the virtual machine is started. For example:
- smbd: On guest: smb://10.0.2.4/qemu
If using a Windows guest, right-click on "This PC", click "Add a network
location", and paste this address, removing `smb:` and replacing forward
slashes with backslashes (in this example `\\10.0.2.4\qemu`).
## SPICE WebDAV 🐧 🪟
- TBD
## VirtIO-9P 🐧 🍏
- TBD
# Network port forwarding
Add an additional line to your virtual machine configuration. For
example:
- `port_forwards=("8123:8123" "8888:80")`
In the example above:
- Port 8123 on the host is forwarded to port 8123 on the guest.
- Port 8888 on the host is forwarded to port 80 on the guest.
# Disable networking
To completely disable all network interfaces in a guest VM add this
additional line to your virtual machine configuration:
- `network="none"`
# Restricted networking
You can isolate the guest from the host (and broader network) using the
restrict option, which will restrict networking to just the guest and
any virtual devices.
This can be used to prevent software running inside the guest from
phoning home while still providing a network inside the guest. Add this
additional line to your virtual machine configuration:
- `network="restrict"`
# Bridged networking
Connect your virtual machine to a preconfigured network bridge. Add an
additional line to your virtual machine configuration:
- `network="br0"`
If you want to have a persistent MAC address for your bridged network
interface in the guest VM you can add `macaddr` to the virtual machine
configuration. QEMU requires that the MAC address is in the range:
**52:54:00:AB:00:00 - 52:54:00:AB:FF:FF**
So you can generate your own MAC addresses with:
- `macaddr="52:54:00:AB:51:AE"`
# USB redirection
Quickemu supports USB redirection via SPICE pass-through and host
pass-through.
## SPICE redirection (recommended)
Using SPICE for USB pass-through is easiest as it doesn't require any
elevated permission, start Quickemu with `--display spice` and then
select `Input` -\> `Select USB Device for redirection` from the menu to
choose which device(s) you want to attach to the guest.
## Host redirection **NOT Recommended**
**USB host redirection is not recommended**, it is provided purely for
backwards compatibility to older versions of Quickemu. Using SPICE is
preferred, see above.
Add an additional line to your virtual machine configuration. For
example:
- `usb_devices=("046d:082d" "046d:085e")`
In the example above:
- The USB device with vendor_id 046d and product_id 082d will be
exposed to the guest.
- The USB device with vendor_id 046d and product_id 085e will be
exposed to the guest.
If the USB devices are not writable, `quickemu` will display the
appropriate commands to modify the USB device(s) access permissions,
like this:
- USB: Host pass-through requested:
- Sennheiser Communications EPOS GTW 270 on bus 001 device 005 needs permission changes:
sudo chown -v root:user /dev/bus/usb/001/005
ERROR! USB permission changes are required 👆
# TPM
Since Quickemu 2.2.0 a software emulated TPM device can be added to
guest virtual machines. Just add `tpm="on"` to your VM configuration.
`quickget` will automatically add this line to Windows 11 virtual
machines.
# AUTHORS
Written by Martin Wimpress.
# BUGS
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
# SEE ALSO
Full sources at: <https://github.com/quickemu-project/quickemu>
quickget(1), quickemu(1), quickgui(1)

532
documents/quickget.1 Normal file
View File

@ -0,0 +1,532 @@
.\" Automatically generated by Pandoc 2.19.2
.\"
.\" Define V font for inline verbatim, using C font in formats
.\" that render this, and otherwise B font.
.ie "\f[CB]x\f[]"x" \{\
. ftr V B
. ftr VI BI
. ftr VB B
. ftr VBI BI
.\}
.el \{\
. ftr V CR
. ftr VI CI
. ftr VB CB
. ftr VBI CBI
.\}
.TH "QUICKGET" "1" "February 4, 2023" "quickget" "Quickget User Manual"
.hy
.SH NAME
.PP
quickget - download and prepare materials for building a quickemu VM
.SH SYNOPSIS
.PP
\f[B]quickget\f[R] [\f[I]os\f[R]] [\f[I]release\f[R]]
[\f[I]edition\f[R]] | [\f[I]OPTION\f[R]]*
.SH DESCRIPTION
.PP
\f[B]quickget\f[R] will download the requisite materials and prepare a
configuration for \f[V]quickemu\f[R] to use to build and run
.SH OPTIONS
.TP
\f[B]version | -version | \[en]version\f[R]
show version (from Quickemu)
.TP
\f[B]list | list_csv | list_json\f[R]
provide a csv list of all supported guest OSes, versions and variants.
.TP
\f[B][OS] [Release] [Edition]\f[R]
specify the OS and release (and optional edition) if insufficient input
is provided a list of missing options will be reported and the script
will exit.
Editions may not apply and will be defaulted if not provided.
.SH NOTES
.SS Ubuntu Guest
.PP
\f[V]quickget\f[R] will automatically download an Ubuntu release and
create the virtual machine configuration.
.IP
.nf
\f[C]
quickget ubuntu 22.04
quickemu --vm ubuntu-22.04.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as normal.
.IP \[bu] 2
Post-install:
.RS 2
.IP \[bu] 2
Install the SPICE agent (\f[V]spice-vdagent\f[R]) in the guest to enable
copy/paste and USB redirection
.RS 2
.IP \[bu] 2
\f[V]sudo apt install spice-vdagent\f[R]
.RE
.IP \[bu] 2
Install the SPICE WebDAV agent (\f[V]spice-webdavd\f[R]) in the guest to
enable file sharing.
.RS 2
.IP \[bu] 2
\f[V]sudo apt install spice-webdavd\f[R]
.RE
.RE
.SS Ubuntu devel (daily-live) images
.PP
\f[V]quickget\f[R] can also download/refresh devel images via
\f[V]zsync\f[R] for Ubuntu developers and testers.
.IP
.nf
\f[C]
quickget ubuntu devel
quickemu --vm ubuntu-devel.conf
\f[R]
.fi
.PP
You can run \f[V]quickget ubuntu devel\f[R] to refresh your daily
development image as often as you like, it will even automatically
switch to a new series.
.SS Ubuntu Flavours
.PP
All the official Ubuntu flavours are supported, just replace
\f[V]ubuntu\f[R] with your preferred flavour.
.IP \[bu] 2
\f[V]kubuntu\f[R] (Kubuntu)
.IP \[bu] 2
\f[V]lubuntu\f[R] (Lubuntu)
.IP \[bu] 2
\f[V]ubuntu-budgie\f[R] (Ubuntu Budgie)
.IP \[bu] 2
\f[V]ubuntukylin\f[R] (Ubuntu Kylin)
.IP \[bu] 2
\f[V]ubuntu-mate\f[R] (Ubuntu MATE)
.IP \[bu] 2
\f[V]ubuntustudio\f[R] (Ubuntu Studio)
.IP \[bu] 2
\f[V]ubuntu\f[R] (Ubuntu)
.IP \[bu] 2
\f[V]ubuntu-unity\f[R] (Ubuntu Unity)
.IP \[bu] 2
\f[V]xubuntu\f[R] (Xubuntu)
.SS Other Operating Systems
.PP
\f[V]quickget\f[R] also supports:
.IP \[bu] 2
\f[V]alma\f[R] (Alma Linux)
.IP \[bu] 2
\f[V]alpine\f[R] (Alpine Linux)
.IP \[bu] 2
\f[V]android\f[R] (Android x86)
.IP \[bu] 2
\f[V]archcraft\f[R] (Archcraft)
.IP \[bu] 2
\f[V]archlinux\f[R] (Arch Linux)
.IP \[bu] 2
\f[V]arcolinux\f[R] (Arco Linux)
.IP \[bu] 2
\f[V]batocera\f[R] (Batocera)
.IP \[bu] 2
\f[V]cachyos\f[R] (CachyOS)
.IP \[bu] 2
\f[V]centos-stream\f[R] (CentOS Stream)
.IP \[bu] 2
\f[V]debian\f[R] (Debian)
.IP \[bu] 2
\f[V]deepin\f[R] (Deepin)
.IP \[bu] 2
\f[V]devuan\f[R] (Devuan)
.IP \[bu] 2
\f[V]dragonflybsd\f[R] (DragonFlyBSD)
.IP \[bu] 2
\f[V]elementary\f[R] (elementary OS)
.IP \[bu] 2
\f[V]endeavouros\f[R] (EndeavourOS)
.IP \[bu] 2
\f[V]fedora\f[R] (Fedora)
.IP \[bu] 2
\f[V]freebsd\f[R] (FreeBSD)
.IP \[bu] 2
\f[V]freedos\f[R] (FreeDOS)
.IP \[bu] 2
\f[V]garuda\f[R] (Garuda Linux)
.IP \[bu] 2
\f[V]gentoo\f[R] (Gentoo)
.IP \[bu] 2
\f[V]ghostbsd\f[R] (GhostBSD)
.IP \[bu] 2
\f[V]haiku\f[R] (Haiku)
.IP \[bu] 2
\f[V]kali\f[R] (Kali)
.IP \[bu] 2
\f[V]kdeneon\f[R] (KDE Neon)
.IP \[bu] 2
\f[V]kolibrios\f[R] (KolibriOS)
.IP \[bu] 2
\f[V]linuxmint\f[R] (Linux Mint)
.IP \[bu] 2
\f[V]lmde\f[R] (Linux Mint Debian Edition)
.IP \[bu] 2
\f[V]mageia\f[R] (Mageia)
.IP \[bu] 2
\f[V]manjaro\f[R] (Manjaro)
.IP \[bu] 2
\f[V]mxlinux\f[R] (MX Linux)
.IP \[bu] 2
\f[V]netboot\f[R] (netboot.xyz)
.IP \[bu] 2
\f[V]netbsd\f[R] (NetBSD)
.IP \[bu] 2
\f[V]nixos\f[R] (NixOS)
.IP \[bu] 2
\f[V]openbsd\f[R] (OpenBSD)
.IP \[bu] 2
\f[V]opensuse\f[R] (openSUSE)
.IP \[bu] 2
\f[V]oraclelinux\f[R] (Oracle Linux)
.IP \[bu] 2
\f[V]popos\f[R] (Pop!_OS)
.IP \[bu] 2
\f[V]reactos\f[R] (ReactOS)
.IP \[bu] 2
\f[V]rebornos\f[R] (RebornOS)
.IP \[bu] 2
\f[V]rockylinux\f[R] (Rocky Linux)
.IP \[bu] 2
\f[V]slackware\f[R] (Slackware)
.IP \[bu] 2
\f[V]solus\f[R] (Solus)
.IP \[bu] 2
\f[V]tails\f[R] (Tails)
.IP \[bu] 2
\f[V]truenas-core\f[R] (TrueNAS Core)
.IP \[bu] 2
\f[V]truenas-scale\f[R] (TrueNAS Scale)
.IP \[bu] 2
\f[V]void\f[R] (Void Linux)
.IP \[bu] 2
\f[V]zorin\f[R] (Zorin OS)
.PP
Or you can download a Linux image and manually create a VM
configuration.
.IP \[bu] 2
Download a .iso image of a Linux distribution
.IP \[bu] 2
Create a VM configuration file; for example
\f[V]debian-bullseye.conf\f[R]
.IP
.nf
\f[C]
guest_os=\[dq]linux\[dq]
disk_img=\[dq]debian-bullseye/disk.qcow2\[dq]
iso=\[dq]debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso\[dq]
\f[R]
.fi
.IP \[bu] 2
Use \f[V]quickemu\f[R] to start the virtual machine:
.IP
.nf
\f[C]
quickemu --vm debian-bullseye.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as normal.
.IP \[bu] 2
Post-install:
.RS 2
.IP \[bu] 2
Install the SPICE agent (\f[V]spice-vdagent\f[R]) in the guest to enable
copy/paste and USB redirection.
.IP \[bu] 2
Install the SPICE WebDAV agent (\f[V]spice-webdavd\f[R]) in the guest to
enable file sharing.
.RE
.SS macOS Guest
.PP
\f[V]quickget\f[R] automatically downloads a macOS recovery image and
creates a virtual machine configuration.
.IP
.nf
\f[C]
quickget macos catalina
quickemu --vm macos-catalina.conf
\f[R]
.fi
.PP
macOS \f[V]high-sierra\f[R], \f[V]mojave\f[R], \f[V]catalina\f[R],
\f[V]big-sur\f[R] and \f[V]monterey\f[R] are supported.
.IP \[bu] 2
Use cursor keys and enter key to select the \f[B]macOS Base System\f[R]
.IP \[bu] 2
From \f[B]macOS Utilities\f[R]
.RS 2
.IP \[bu] 2
Click \f[B]Disk Utility\f[R] and \f[B]Continue\f[R]
.RS 2
.IP \[bu] 2
Select \f[V]QEMU HARDDISK Media\f[R] (\[ti]103.08GB) from the list and
click \f[B]Erase\f[R].
.IP \[bu] 2
Enter a \f[V]Name:\f[R] for the disk
.IP \[bu] 2
If you are installing macOS Mojave or later (Catalina, Big Sur, and
Monterey), choose any of the APFS options as the filesystem.
MacOS Extended may not work.
.RE
.IP \[bu] 2
Click \f[B]Erase\f[R].
.IP \[bu] 2
Click \f[B]Done\f[R].
.IP \[bu] 2
Close Disk Utility
.RE
.IP \[bu] 2
From \f[B]macOS Utilities\f[R]
.RS 2
.IP \[bu] 2
Click \f[B]Reinstall macOS\f[R] and \f[B]Continue\f[R]
.RE
.IP \[bu] 2
Complete the installation as you normally would.
.RS 2
.IP \[bu] 2
On the first reboot use cursor keys and enter key to select \f[B]macOS
Installer\f[R]
.IP \[bu] 2
On the subsequent reboots use cursor keys and enter key to select the
disk you named
.RE
.IP \[bu] 2
Once you have finished installing macOS you will be presented with an
the out-of-the-box first-start wizard to configure various options and
set up your username and password
.IP \[bu] 2
OPTIONAL: After you have concluded the out-of-the-box wizard, you may
want to enable the TRIM feature that the computer industry created for
SSD disks.
This feature in our macOS installation will allow QuickEmu to compact
(shrink) your macOS disk image whenever you delete files inside the
Virtual Machine.
Without this step your macOS disk image will only ever get larger and
will not shrink even when you delete lots of data inside macOS.
.RS 2
.IP \[bu] 2
To enable TRIM, open the Terminal application and type the following
command followed by pressing enter to tell macos to use the TRIM command
on the hard disk when files are deleted:
.RE
.IP
.nf
\f[C]
sudo trimforce enable
\f[R]
.fi
.PP
You will be prompted to enter your account\[cq]s password to gain the
privilege needed.
Once you\[cq]ve entered your password and pressed enter the command will
request confirmation in the form of two questions that require you to
type y (for a \[lq]yes\[rq] response) followed by enter to confirm.
If you press enter without first typing y the system will consider that
a negative response as though you said \[lq]no\[rq]:
.IP
.nf
\f[C]
IMPORTANT NOTICE: This tool force-enables TRIM for all relevant attached devices, even though such devices may not have been validated for data integrity while using TRIM. Use of this tool to enable TRIM may result in unintended data loss or data corruption. It should not be used in a commercial operating environment or with important data. Before using this tool, you should back up all of your data and regularly back up data while TRIM is enabled. This tool is provided on an \[dq]as is\[dq] basis. APPLE MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THIS TOOL OR ITS USE ALONE OR IN COMBINATION WITH YOUR DEVICES, SYSTEMS, OR SERVICES. BY USING THIS TOOL TO ENABLE TRIM, YOU AGREE THAT, TO THE EXTENT PERMITTED BY APPLICABLE LAW, USE OF THE TOOL IS AT YOUR SOLE RISK AND THAT THE ENTIRE RISK AS TO SATISFACTORY QUALITY, PERFORMANCE, ACCURACY AND EFFORT IS WITH YOU.
Are you sure you with to proceed (y/N)?
\f[R]
.fi
.PP
And a second confirmation once you\[cq]ve confirmed the previous one:
.IP
.nf
\f[C]
Your system will immediately reboot when this is complete.
Is this OK (y/N)?
\f[R]
.fi
.PP
As the last message states, your system will automatically reboot as
soon as the command completes.
.PP
The default macOS configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]macos\[dq]
img=\[dq]macos-catalina/RecoveryImage.img\[dq]
disk_img=\[dq]macos-catalina/disk.qcow2\[dq]
macos_release=\[dq]catalina\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]macos\[dq]\f[R] instructs Quickemu to optimise for
macOS.
.IP \[bu] 2
\f[V]macos_release=\[dq]catalina\[dq]\f[R] instructs Quickemu to
optimise for a particular macOS release.
.RS 2
.IP \[bu] 2
For example VirtIO Network and Memory Ballooning are available in Big
Sur and newer, but not previous releases.
.IP \[bu] 2
And VirtIO Block Media (disks) are supported/stable in Catalina and
newer.
.RE
.SS macOS compatibility
.PP
There are some considerations when running macOS via Quickemu.
.IP \[bu] 2
Supported macOS releases:
.RS 2
.IP \[bu] 2
High Sierra
.IP \[bu] 2
Mojave
.IP \[bu] 2
Catalina \f[B](Recommended)\f[R]
.IP \[bu] 2
Big Sur
.IP \[bu] 2
Monterey
.RE
.IP \[bu] 2
\f[V]quickemu\f[R] will automatically download the required
OpenCore (https://github.com/acidanthera/OpenCorePkg) bootloader and
OVMF firmware from OSX-KVM (https://github.com/kholia/OSX-KVM).
.IP \[bu] 2
Optimised by default, but no GPU acceleration is available.
.RS 2
.IP \[bu] 2
Host CPU vendor is detected and guest CPU is optimised accordingly.
.IP \[bu] 2
VirtIO Block
Media (https://www.kraxel.org/blog/2019/06/macos-qemu-guest/) is used
for the system disk where supported.
.IP \[bu] 2
VirtIO \f[V]usb-tablet\f[R] (http://philjordan.eu/osx-virt/) is used for
the mouse.
.IP \[bu] 2
VirtIO Network (\f[V]virtio-net\f[R]) is supported and enabled on macOS
Big Sur and newer but previous releases use \f[V]vmxnet3\f[R].
.IP \[bu] 2
VirtIO Memory Ballooning is supported and enabled on macOS Big Sur and
newer but disabled for other support macOS releases.
.RE
.IP \[bu] 2
USB host and SPICE pass-through is:
.RS 2
.IP \[bu] 2
UHCI (USB 2.0) on macOS Catalina and earlier.
.IP \[bu] 2
XHCI (USB 3.0) on macOS Big Sur and newer.
.RE
.IP \[bu] 2
Display resolution can only be changed via macOS System Preferences.
.IP \[bu] 2
\f[B]Full Duplex audio requires VoodooHDA
OC (https://github.com/chris1111/VoodooHDA-OC) or pass-through a USB
audio-device to the macOS guest VM\f[R].
.IP \[bu] 2
NOTE!
Gatekeeper (https://disable-gatekeeper.github.io/) and System Integrity
Protection
(SIP) (https://developer.apple.com/documentation/security/disabling_and_enabling_system_integrity_protection)
need to be disabled to install VoodooHDA OC
.IP \[bu] 2
File sharing between guest and host is available via
virtio-9p (https://wiki.qemu.org/Documentation/9psetup) and SPICE
webdavd (https://gitlab.gnome.org/GNOME/phodav/-/merge_requests/24).
.IP \[bu] 2
Copy/paste via SPICE agent is \f[B]not available on macOS\f[R].
.SS macOS App Store
.PP
If you see \f[I]\[lq]Your device or computer could not be
verified\[rq]\f[R] when you try to login to the App Store, make sure
that your wired ethernet device is \f[V]en0\f[R].
Use \f[V]ifconfig\f[R] in a terminal to verify this.
.PP
If the wired ethernet device is not \f[V]en0\f[R], then then go to
\f[I]System Preferences\f[R] -> \f[I]Network\f[R], delete all the
network devices and apply the changes.
Next, open a terminal and run the following:
.IP
.nf
\f[C]
sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
\f[R]
.fi
.PP
Now reboot, and the App Store should work.
.SS Windows 10 & 11 Guests
.PP
\f[V]quickget\f[R] can not download
Windows10 (https://www.microsoft.com/software-download/windows10) and
Windows 11 (https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
This configuration also includes the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
\f[V]quickget\f[R] can automatically download Windows 8.1, Windows
10 (https://www.microsoft.com/en-gb/software-download/windows10ISO) and
Windows 11 (https://www.microsoft.com/en-gb/software-download/windows11)
along with the VirtIO drivers for
Windows (https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
.IP
.nf
\f[C]
quickget windows 11
quickemu --vm windows-11.conf
\f[R]
.fi
.IP \[bu] 2
Complete the installation as you normally would.
.IP \[bu] 2
All relevant drivers and services should be installed automatically.
.IP \[bu] 2
A local adminstrator user account is automatically created, with these
credentials:
.RS 2
.IP \[bu] 2
Username: \f[V]Quickemu\f[R]
.IP \[bu] 2
Password: \f[V]quickemu\f[R]
.RE
.PP
The default Windows 11 configuration looks like this:
.IP
.nf
\f[C]
guest_os=\[dq]windows\[dq]
disk_img=\[dq]windows-11/disk.qcow2\[dq]
iso=\[dq]windows-11/windows-11.iso\[dq]
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
tpm=\[dq]on\[dq]
secureboot=\[dq]on\[dq]
\f[R]
.fi
.IP \[bu] 2
\f[V]guest_os=\[dq]windows\[dq]\f[R] instructs \f[V]quickemu\f[R] to
optimise for Windows.
.IP \[bu] 2
\f[V]fixed_iso=\f[R] specifies the ISO image that provides VirtIO
drivers.
.IP \[bu] 2
\f[V]tpm=\[dq]on\[dq]\f[R] instructs \f[V]quickemu\f[R] to create a
software emulated TPM device using \f[V]swtpm\f[R].
.SH AUTHORS
.PP
Written by Martin Wimpress.
.SH BUGS
.PP
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
.SH SEE ALSO
.PP
Full sources at: <https://github.com/quickemu-project/quickemu>
.PP
quickemu(1), quickemu_conf(1), quickgui(1)
.SH AUTHORS
Martin Wimpress.

373
documents/quickget.1.md Normal file
View File

@ -0,0 +1,373 @@
---
author: Martin Wimpress
date: February 4, 2023
footer: quickget
header: Quickget User Manual
section: 1
title: QUICKGET
---
# NAME
quickget - download and prepare materials for building a quickemu VM
# SYNOPSIS
**quickget** \[*os*\] \[*release*\] \[*edition*\] \| \[*OPTION*\]\*
# DESCRIPTION
**quickget** will download the requisite materials and prepare a
configuration for `quickemu` to use to build and run
# OPTIONS
**version \| -version \| --version**
: show version (from Quickemu)
**list \| list_csv \| list_json**
: provide a csv list of all supported guest OSes, versions and
variants.
**\[OS\] \[Release\] \[Edition\]**
: specify the OS and release (and optional edition) if insufficient
input is provided a list of missing options will be reported and the
script will exit. Editions may not apply and will be defaulted if
not provided.
# NOTES
## Ubuntu Guest
`quickget` will automatically download an Ubuntu release and create the
virtual machine configuration.
``` bash
quickget ubuntu 22.04
quickemu --vm ubuntu-22.04.conf
```
- Complete the installation as normal.
- Post-install:
- Install the SPICE agent (`spice-vdagent`) in the guest to enable
copy/paste and USB redirection
- `sudo apt install spice-vdagent`
- Install the SPICE WebDAV agent (`spice-webdavd`) in the guest to
enable file sharing.
- `sudo apt install spice-webdavd`
### Ubuntu devel (daily-live) images
`quickget` can also download/refresh devel images via `zsync` for Ubuntu
developers and testers.
``` bash
quickget ubuntu devel
quickemu --vm ubuntu-devel.conf
```
You can run `quickget ubuntu devel` to refresh your daily development
image as often as you like, it will even automatically switch to a new
series.
### Ubuntu Flavours
All the official Ubuntu flavours are supported, just replace `ubuntu`
with your preferred flavour.
- `kubuntu` (Kubuntu)
- `lubuntu` (Lubuntu)
- `ubuntu-budgie` (Ubuntu Budgie)
- `ubuntukylin` (Ubuntu Kylin)
- `ubuntu-mate` (Ubuntu MATE)
- `ubuntustudio` (Ubuntu Studio)
- `ubuntu` (Ubuntu)
- `ubuntu-unity` (Ubuntu Unity)
- `xubuntu` (Xubuntu)
## Other Operating Systems
`quickget` also supports:
- `alma` (Alma Linux)
- `alpine` (Alpine Linux)
- `android` (Android x86)
- `archcraft` (Archcraft)
- `archlinux` (Arch Linux)
- `arcolinux` (Arco Linux)
- `batocera` (Batocera)
- `cachyos` (CachyOS)
- `centos-stream` (CentOS Stream)
- `debian` (Debian)
- `deepin` (Deepin)
- `devuan` (Devuan)
- `dragonflybsd` (DragonFlyBSD)
- `elementary` (elementary OS)
- `endeavouros` (EndeavourOS)
- `fedora` (Fedora)
- `freebsd` (FreeBSD)
- `freedos` (FreeDOS)
- `garuda` (Garuda Linux)
- `gentoo` (Gentoo)
- `ghostbsd` (GhostBSD)
- `haiku` (Haiku)
- `kali` (Kali)
- `kdeneon` (KDE Neon)
- `kolibrios` (KolibriOS)
- `linuxmint` (Linux Mint)
- `lmde` (Linux Mint Debian Edition)
- `mageia` (Mageia)
- `manjaro` (Manjaro)
- `mxlinux` (MX Linux)
- `netboot` (netboot.xyz)
- `netbsd` (NetBSD)
- `nixos` (NixOS)
- `openbsd` (OpenBSD)
- `opensuse` (openSUSE)
- `oraclelinux` (Oracle Linux)
- `popos` (Pop!\_OS)
- `reactos` (ReactOS)
- `rebornos` (RebornOS)
- `rockylinux` (Rocky Linux)
- `slackware` (Slackware)
- `solus` (Solus)
- `tails` (Tails)
- `truenas-core` (TrueNAS Core)
- `truenas-scale` (TrueNAS Scale)
- `void` (Void Linux)
- `zorin` (Zorin OS)
Or you can download a Linux image and manually create a VM
configuration.
- Download a .iso image of a Linux distribution
- Create a VM configuration file; for example `debian-bullseye.conf`
``` bash
guest_os="linux"
disk_img="debian-bullseye/disk.qcow2"
iso="debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso"
```
- Use `quickemu` to start the virtual machine:
``` bash
quickemu --vm debian-bullseye.conf
```
- Complete the installation as normal.
- Post-install:
- Install the SPICE agent (`spice-vdagent`) in the guest to enable
copy/paste and USB redirection.
- Install the SPICE WebDAV agent (`spice-webdavd`) in the guest to
enable file sharing.
## macOS Guest
`quickget` automatically downloads a macOS recovery image and creates a
virtual machine configuration.
``` bash
quickget macos catalina
quickemu --vm macos-catalina.conf
```
macOS `high-sierra`, `mojave`, `catalina`, `big-sur` and `monterey` are
supported.
- Use cursor keys and enter key to select the **macOS Base System**
- From **macOS Utilities**
- Click **Disk Utility** and **Continue**
- Select `QEMU HARDDISK Media` (\~103.08GB) from the list and
click **Erase**.
- Enter a `Name:` for the disk
- If you are installing macOS Mojave or later (Catalina, Big
Sur, and Monterey), choose any of the APFS options as the
filesystem. MacOS Extended may not work.
- Click **Erase**.
- Click **Done**.
- Close Disk Utility
- From **macOS Utilities**
- Click **Reinstall macOS** and **Continue**
- Complete the installation as you normally would.
- On the first reboot use cursor keys and enter key to select
**macOS Installer**
- On the subsequent reboots use cursor keys and enter key to
select the disk you named
- Once you have finished installing macOS you will be presented with
an the out-of-the-box first-start wizard to configure various
options and set up your username and password
- OPTIONAL: After you have concluded the out-of-the-box wizard, you
may want to enable the TRIM feature that the computer industry
created for SSD disks. This feature in our macOS installation will
allow QuickEmu to compact (shrink) your macOS disk image whenever
you delete files inside the Virtual Machine. Without this step your
macOS disk image will only ever get larger and will not shrink even
when you delete lots of data inside macOS.
- To enable TRIM, open the Terminal application and type the
following command followed by pressing
`<kbd>`{=html}enter`</kbd>`{=html} to tell macos to use the TRIM
command on the hard disk when files are deleted:
``` bash
sudo trimforce enable
```
You will be prompted to enter your account's password to gain the
privilege needed. Once you've entered your password and pressed
`<kbd>`{=html}enter`</kbd>`{=html} the command will request confirmation
in the form of two questions that require you to type
`<kbd>`{=html}y`</kbd>`{=html} (for a "yes" response) followed by
`<kbd>`{=html}enter`</kbd>`{=html} to confirm. If you press
`<kbd>`{=html}enter`</kbd>`{=html} without first typing
`<kbd>`{=html}y`</kbd>`{=html} the system will consider that a negative
response as though you said "no":
``` plain
IMPORTANT NOTICE: This tool force-enables TRIM for all relevant attached devices, even though such devices may not have been validated for data integrity while using TRIM. Use of this tool to enable TRIM may result in unintended data loss or data corruption. It should not be used in a commercial operating environment or with important data. Before using this tool, you should back up all of your data and regularly back up data while TRIM is enabled. This tool is provided on an "as is" basis. APPLE MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THIS TOOL OR ITS USE ALONE OR IN COMBINATION WITH YOUR DEVICES, SYSTEMS, OR SERVICES. BY USING THIS TOOL TO ENABLE TRIM, YOU AGREE THAT, TO THE EXTENT PERMITTED BY APPLICABLE LAW, USE OF THE TOOL IS AT YOUR SOLE RISK AND THAT THE ENTIRE RISK AS TO SATISFACTORY QUALITY, PERFORMANCE, ACCURACY AND EFFORT IS WITH YOU.
Are you sure you with to proceed (y/N)?
```
And a second confirmation once you've confirmed the previous one:
``` plain
Your system will immediately reboot when this is complete.
Is this OK (y/N)?
```
As the last message states, your system will automatically reboot as
soon as the command completes.
The default macOS configuration looks like this:
``` bash
guest_os="macos"
img="macos-catalina/RecoveryImage.img"
disk_img="macos-catalina/disk.qcow2"
macos_release="catalina"
```
- `guest_os="macos"` instructs Quickemu to optimise for macOS.
- `macos_release="catalina"` instructs Quickemu to optimise for a
particular macOS release.
- For example VirtIO Network and Memory Ballooning are available
in Big Sur and newer, but not previous releases.
- And VirtIO Block Media (disks) are supported/stable in Catalina
and newer.
### macOS compatibility
There are some considerations when running macOS via Quickemu.
- Supported macOS releases:
- High Sierra
- Mojave
- Catalina **(Recommended)**
- Big Sur
- Monterey
- `quickemu` will automatically download the required
[OpenCore](https://github.com/acidanthera/OpenCorePkg) bootloader
and OVMF firmware from [OSX-KVM](https://github.com/kholia/OSX-KVM).
- Optimised by default, but no GPU acceleration is available.
- Host CPU vendor is detected and guest CPU is optimised
accordingly.
- [VirtIO Block
Media](https://www.kraxel.org/blog/2019/06/macos-qemu-guest/) is
used for the system disk where supported.
- [VirtIO `usb-tablet`](http://philjordan.eu/osx-virt/) is used
for the mouse.
- VirtIO Network (`virtio-net`) is supported and enabled on macOS
Big Sur and newer but previous releases use `vmxnet3`.
- VirtIO Memory Ballooning is supported and enabled on macOS Big
Sur and newer but disabled for other support macOS releases.
- USB host and SPICE pass-through is:
- UHCI (USB 2.0) on macOS Catalina and earlier.
- XHCI (USB 3.0) on macOS Big Sur and newer.
- Display resolution can only be changed via macOS System Preferences.
- **Full Duplex audio requires [VoodooHDA
OC](https://github.com/chris1111/VoodooHDA-OC) or pass-through a USB
audio-device to the macOS guest VM**.
- NOTE! [Gatekeeper](https://disable-gatekeeper.github.io/) and
[System Integrity Protection
(SIP)](https://developer.apple.com/documentation/security/disabling_and_enabling_system_integrity_protection)
need to be disabled to install VoodooHDA OC
- File sharing between guest and host is available via
[virtio-9p](https://wiki.qemu.org/Documentation/9psetup) and [SPICE
webdavd](https://gitlab.gnome.org/GNOME/phodav/-/merge_requests/24).
- Copy/paste via SPICE agent is **not available on macOS**.
### macOS App Store
If you see *"Your device or computer could not be verified"* when you
try to login to the App Store, make sure that your wired ethernet device
is `en0`. Use `ifconfig` in a terminal to verify this.
If the wired ethernet device is not `en0`, then then go to *System
Preferences* -\> *Network*, delete all the network devices and apply the
changes. Next, open a terminal and run the following:
``` bash
sudo rm /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist
```
Now reboot, and the App Store should work.
## Windows 10 & 11 Guests
`quickget` can not download
[Windows10](https://www.microsoft.com/software-download/windows10) and
[Windows 11](https://www.microsoft.com/software-download/windows11)
automatically, but does automatically create an optimised virtual
machine configuration that you can just add an Windows .iso image to.
This configuration also includes the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/).
`quickget` can automatically download Windows 8.1, [Windows
10](https://www.microsoft.com/en-gb/software-download/windows10ISO) and
[Windows
11](https://www.microsoft.com/en-gb/software-download/windows11) along
with the [VirtIO drivers for
Windows](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/)
and creates a virtual machine configuration.
``` bash
quickget windows 11
quickemu --vm windows-11.conf
```
- Complete the installation as you normally would.
- All relevant drivers and services should be installed automatically.
- A local adminstrator user account is automatically created, with
these credentials:
- Username: `Quickemu`
- Password: `quickemu`
The default Windows 11 configuration looks like this:
``` bash
guest_os="windows"
disk_img="windows-11/disk.qcow2"
iso="windows-11/windows-11.iso"
fixed_iso="windows-11/virtio-win.iso"
tpm="on"
secureboot="on"
```
- `guest_os="windows"` instructs `quickemu` to optimise for Windows.
- `fixed_iso=` specifies the ISO image that provides VirtIO drivers.
- `tpm="on"` instructs `quickemu` to create a software emulated TPM
device using `swtpm`.
# AUTHORS
Written by Martin Wimpress.
# BUGS
Submit bug reports online at:
<https://github.com/quickemu-project/quickemu/issues>
# SEE ALSO
Full sources at: <https://github.com/quickemu-project/quickemu>
quickemu(1), quickemu_conf(1), quickgui(1)

147
documents/source.pot Normal file
View File

@ -0,0 +1,147 @@
#: dh.sh:10
msgid "Done"
msgstr ""
#: dh.sh:11
msgid "PS: You saw some bugs?"
msgstr ""
#: dh.sh:12
msgid "Could you please provide feedback?"
msgstr ""
#: dh.sh:13
msgid "How do you like DistroHopper?"
msgstr ""
#: dh.sh:14
msgid "What can be improved, added, changed?"
msgstr ""
#: dh.sh:15
msgid " Let me know..."
msgstr ""
#: dh.sh:16
msgid "Flawless distro hopping..."
msgstr ""
#: dh.sh:21
msgid "Possible arguments:"
msgstr ""
#: dh.sh:22
msgid " -h --help Show this help and exit"
msgstr ""
#: dh.sh:24
msgid " -d --dir Set default directory where VMs are stored"
msgstr ""
#: dh.sh:25
msgid " -i --install Install DistroHopper"
msgstr ""
#: dh.sh:27
msgid " -m --mode Portable mode"
msgstr ""
#: dh.sh:29
msgid " -s --supported Update supported VMs"
msgstr ""
#: dh.sh:30
msgid " -r --ready Update ready to run VMs"
msgstr ""
#: dh.sh:32
msgid " -t --tui Run TUI"
msgstr ""
#: dh.sh:33
msgid " -g --gui Run GUI"
msgstr ""
#: dh.sh:35
msgid " -a --add Add new distro to quickget"
msgstr ""
#: dh.sh:36
msgid " -f --functions Sort functions in quickget"
msgstr ""
#: dh.sh:37
msgid " -p --push Push changed quickget to quickemu project #todo"
msgstr ""
#: dh.sh:39
msgid " -c --copy Copy all ISOs to target dir (for Ventoy)"
msgstr ""
#: dh.sh:41
msgid "Homepage: dh.osowoso.xyz"
msgstr ""
#: dh.sh:42
msgid "Project hosted at: https://github.com/oSoWoSo/DistroHopper"
msgstr ""
#: dh.sh:43
msgid "Chat group on SimpleX: https://tinyurl.com/7hm4kcjx"
msgstr ""
#: dh.sh:66
msgid "Missing yad!"
msgstr ""
#: dh.sh:70
msgid "Missing fzf!"
msgstr ""
#: dh.sh:93
msgid "creating config dir..."
msgstr ""
#: dh.sh:95
msgid "creating icons dir as root..."
msgstr ""
#: dh.sh:118
msgid "Copying icons..."
msgstr ""
#: dh.sh:120
msgid "Copying to config dir..."
msgstr ""
#: dh.sh:130
msgid "Creating directory structure..."
msgstr ""
#: dh.sh:132
msgid "Setting up directory..."
msgstr ""
#: dh.sh:134
msgid "Installing needed..."
msgstr ""
#: dh.sh:135
msgid "For now voidlinux only"
msgstr ""
#: dh.sh:137
msgid "Installing DistroHopper to bin..."
msgstr ""
#: dh.sh:279
msgid "No VMs found."
msgstr ""
#: dh.sh:411
msgid "Which language you want use [en_US cs_CZ]?"
msgstr ""
#: dh.sh:438
msgid "No argumet provided!\\n\\n"
msgstr ""
#: dh.sh:456
msgid "Starting installation..."
msgstr ""
#: dh.sh:461
msgid "Switching to portable mode!"
msgstr ""
#: dh.sh:466
msgid "Updating supported VMs..."
msgstr ""
#: dh.sh:471
msgid "Updating ready VMs..."
msgstr ""
#: dh.sh:476
msgid "Running TUI..."
msgstr ""
#: dh.sh:481
msgid "Starting DistroHopper GUI..."
msgstr ""
#: dh.sh:486
msgid "Adding new distro started..."
msgstr ""
#: dh.sh:491
msgid "Sorting functions in template..."
msgstr ""
#: dh.sh:496
msgid "Pushing changes to... #TODO"
msgstr ""
#: dh.sh:501
msgid "Copying ISOs to dir. It will take some time..."
msgstr ""
#: dh.sh:506
msgid "Running supported test..."
msgstr ""
#: dh.sh:515
msgid "Invalid option: $1\\n\\n"
msgstr ""

View File

@ -35,11 +35,13 @@ linuxmint
lmde
mageia
manjaro
miyo
mxlinux
netboot
netbsd
nixos
lubuntu
macos
openbsd
opensuse
oraclelinux
@ -61,9 +63,11 @@ ubuntukylin
ubuntu-mate
ubuntustudio
ubuntu-unity
ventoy
void
voidpup
vxlinux
windows
xerolinux
xubuntu
zorin

View File

Before

Width:  |  Height:  |  Size: 4.4 KiB

After

Width:  |  Height:  |  Size: 4.4 KiB

View File

Before

Width:  |  Height:  |  Size: 3.1 KiB

After

Width:  |  Height:  |  Size: 3.1 KiB

24340
icons/agarimos.svg Normal file

File diff suppressed because it is too large Load Diff

After

Width:  |  Height:  |  Size: 1.1 MiB

View File

Before

Width:  |  Height:  |  Size: 3.4 KiB

After

Width:  |  Height:  |  Size: 3.4 KiB

View File

Before

Width:  |  Height:  |  Size: 5.2 KiB

After

Width:  |  Height:  |  Size: 5.2 KiB

View File

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

View File

Before

Width:  |  Height:  |  Size: 2.9 KiB

After

Width:  |  Height:  |  Size: 2.9 KiB

View File

Before

Width:  |  Height:  |  Size: 3.8 KiB

After

Width:  |  Height:  |  Size: 3.8 KiB

View File

Before

Width:  |  Height:  |  Size: 798 B

After

Width:  |  Height:  |  Size: 798 B

View File

Before

Width:  |  Height:  |  Size: 3.2 KiB

After

Width:  |  Height:  |  Size: 3.2 KiB

View File

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

View File

Before

Width:  |  Height:  |  Size: 3.1 KiB

After

Width:  |  Height:  |  Size: 3.1 KiB

View File

Before

Width:  |  Height:  |  Size: 7.6 KiB

After

Width:  |  Height:  |  Size: 7.6 KiB

View File

Before

Width:  |  Height:  |  Size: 846 B

After

Width:  |  Height:  |  Size: 846 B

View File

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

View File

Before

Width:  |  Height:  |  Size: 2.9 KiB

After

Width:  |  Height:  |  Size: 2.9 KiB

744
icons/athenaos.svg Normal file
View File

@ -0,0 +1,744 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->
<svg
version="1.1"
id="svg104"
width="682.66669"
height="682.66669"
viewBox="0 0 682.66669 682.66669"
xmlns:xlink="http://www.w3.org/1999/xlink"
xmlns="http://www.w3.org/2000/svg"
xmlns:svg="http://www.w3.org/2000/svg">
<defs
id="defs108" />
<g
id="g110">
<image
width="682.66669"
height="682.66669"
preserveAspectRatio="none"
xlink:href="
+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
"
id="image112" />
</g>
</svg>

After

Width:  |  Height:  |  Size: 55 KiB

View File

Before

Width:  |  Height:  |  Size: 4.0 KiB

After

Width:  |  Height:  |  Size: 4.0 KiB

View File

Before

Width:  |  Height:  |  Size: 9.2 KiB

After

Width:  |  Height:  |  Size: 9.2 KiB

52
icons/biglinux.svg Normal file

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 33 KiB

View File

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 11 KiB

196645
icons/blendos.svg Normal file

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 9.3 MiB

View File

Before

Width:  |  Height:  |  Size: 5.2 KiB

After

Width:  |  Height:  |  Size: 5.2 KiB

View File

Before

Width:  |  Height:  |  Size: 2.7 KiB

After

Width:  |  Height:  |  Size: 2.7 KiB

View File

Before

Width:  |  Height:  |  Size: 8.1 KiB

After

Width:  |  Height:  |  Size: 8.1 KiB

Some files were not shown because too many files have changed in this diff Show More