Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/arthurchoung/HOTDOG
X11 Window Manager with Windows 3.1 Hot Dog Stand, Amiga Workbench, Atari ST GEM, Mac Classic and Aqua UI
https://github.com/arthurchoung/HOTDOG
objective-c window-manager
Last synced: about 2 months ago
JSON representation
X11 Window Manager with Windows 3.1 Hot Dog Stand, Amiga Workbench, Atari ST GEM, Mac Classic and Aqua UI
- Host: GitHub
- URL: https://github.com/arthurchoung/HOTDOG
- Owner: arthurchoung
- License: gpl-3.0
- Created: 2020-07-08T18:01:05.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-08-10T10:49:18.000Z (5 months ago)
- Last Synced: 2024-08-10T11:52:33.746Z (5 months ago)
- Topics: objective-c, window-manager
- Language: Objective-C
- Homepage:
- Size: 45.5 MB
- Stars: 300
- Watchers: 6
- Forks: 9
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-ricing - HOTDOG - X11 Window Manager with Windows 3.1 Hot Dog Stand, Amiga Workbench, Atari ST GEM, and Classic Mac UI. (objective-c) (Packages / window-managers)
README
# HOTDOG
## Download
Installer ISO based on Slackware64 (1.28 GB)
Minimal ISO based on Slackware64 that runs from RAM (192 MB)
Boot with Legacy BIOS.
If using VirtualBox, 3D acceleration should be enabled.
This is a multilib system, the only 32-bit application included is Wine.
It comes with the 64-bit gcc only, so the included gcc cannot create 32 bit binaries.
It is a stripped down system that does not include systemd, wayland, elogind, polkit, pulseaudio, or NetworkManager.
http://fmamp.com/download/
## Hot Dog (Linux) on a (USB) stick
To write the image to a USB drive:
$ dd if=/path/to/file.iso of=/dev/sdX bs=1M
/path/to/file.iso is the file name of the image file.
/dev/sdX is the USB device to write the image to.
Run as root. Be careful not to write to the wrong drive.
## Webpage
https://fmamp.com/hotdoglinux/
## Overview
The design goals of HOTDOG include:
* Graphical user interface based on retro computer systems including Hot Dog Stand (Windows 3.1), Amiga Workbench, Atari ST GEM, Mac Classic and Aqua
* Custom lightweight Objective-C foundation
* Bitmapped graphics, low DPI displays
* No Unicode support by designHOTDOG uses a custom lightweight Objective-C foundation on top of the GCC Objective-C runtime. The style of Objective-C is completely different from the one Apple uses, everything is basically **id**.
Alternatively, it is possible to use an older version of the GNUstep Objective-C runtime that uses the old object struct layout (located in external/libobjc2). This requires everything to be compiled with clang, and allows for the use of Objective-C 2.0 features such as NSFastEnumeration and NSArray/NSDictionary literals, as well as blocks and libdispatch (with the appropriate libs). However, the GCC runtime has better performance, so it is the default.
By design, Unicode is not supported.
Low DPI displays are preferred, since the graphics are bitmapped and fixed in size.
HOTDOG does not use Automatic Reference Counting. It causes problems with type-checking during compilation (it is too strict).
HOTDOG is an acronym that stands for **H**orrible **O**bsolete **T**ypeface and **D**readful **O**nscreen **G**raphics.
## How to compile and run
$ sh makeUtils.sh
$ perl build.pl
To run the window manager:
$ ./hotdog runWindowManager
To run the iPod style interface:
$ ./hotdog
## Notes
Aqua mode uses 'compton' for window drop shadows and 'feh' to set the wallpaper.
Some of the Perl scripts use the JSON module.
## Screenshots
WinMac 1280x1024
WinMac is a combination of the Windows 3.1 window borders and font, the classic Mac menu bar, and dialogs featuring CATS from Zero Wing (All your base are belong to us).
![WinMac Screenshot](Screenshots/hotdog-screenshot-winmac.png)
Hot Dog Stand 1280x1024
![Hot Dog Stand Screenshot](Screenshots/hotdog-screenshot-win31.png)
Atari ST GEM 1280x1024
![Atari ST Screenshot](Screenshots/hotdog-screenshot-atarist.png)
Amiga Screenshot 1280x1024
![Amiga Screenshot](Screenshots/hotdog-screenshot-amiga.png)
Mac Classic 1280x1024
![Mac Classic Screenshot](Screenshots/hotdog-screenshot-macclassic.png)
Mac Color 1280x1024
![Mac Color Screenshot](Screenshots/hotdog-screenshot-maccolor.png)
Mac Platinum 1280x1024
![Mac Platinum Screenshot](Screenshots/hotdog-screenshot-macplatinum.png)
Aqua 1280x1024
![Aqua Screenshot](Screenshots/hotdog-screenshot-aqua.png)
## iOS 4/5/6
This is an attempt to recreate iOS 4/5/6 with simplified graphics that would be suitable for the 8-bit or 16-bit era.
### Home Screen
This is a preliminary version of the home screen with Windows 3 icons.
![Home Screen](Screenshots/hotdog-homescreen.png)
### Music
A music browser in the style of the old versions of iOS.
Displays a list based on the files in the current directory, using the output of the following scripts:
* hotdog-music-listAlbumsForArtist:.py
* hotdog-music-listArtists.py
* hotdog-music-listSongsForArtist:.py
* hotdog-music-listTracksForAlbum:.pyThese scripts can be modified as desired.
Currently requires Python modules mutagen and pillow.
To show albums:
```
$ hotdog show AlbumListNavigation
```![Music Screenshot Album](Screenshots/hotdog-music-screenshot-album.png)
Click on an album to list the tracks:
![Music Screenshot Track](Screenshots/hotdog-music-screenshot-track.png)
To show songs:
```
$ hotdog show SongListNavigation
```![Music Screenshot Song](Screenshots/hotdog-music-screenshot-song.png)
To show artists:
```
$ hotdog show ArtistListNavigation
```![Music Screenshot Artist](Screenshots/hotdog-music-screenshot-artist.png)
### Contacts
A vcf/vcard browser in the style of the old versions of iOS.
Displays a list based on the files in the current directory, using the output of the following scripts:
* hotdog-contacts-list.py
* hotdog-contacts-printFile:.pyThese scripts can be modified as desired.
Currently requires Python modules vobject and pillow.
To show list:
```
$ hotdog show ContactListNavigation
```![Contacts Screenshot List](Screenshots/hotdog-contacts-screenshot-list.png)
Click on a row to show details:
![Contacts Screenshot Detail](Screenshots/hotdog-contacts-screenshot-detail.png)
### Calendar
Displays a calendar using the output of 'cal' for the actual calendar.
The script 'hotdog-calendar-listEvents.py' reads .ics files in the current directory and lists the event dates, which are highlighted in yellow.
These scripts can be modified as desired.
Currently requires Python module vobject.
To show a yearly calendar:
```
$ hotdog show CalendarInterface
```![Calendar Screenshot Year](Screenshots/hotdog-calendar-screenshot-year.png)
### Lock Screen
```
$ hotdog show LockScreen
```![Lock Screen](Screenshots/hotdog-lockscreen.png)
## Legal
Copyright (c) 2020 Arthur Choung. All rights reserved.
Email: arthur -at- fmamp.com
Released under the GNU General Public License, version 3.
For details on the license, refer to the LICENSE file.