MUGS::UI::Pop - Pop/SDL UI for MUGS, including App and game UIs
# Set up a full-stack MUGS-UI-Pop development environment
mkdir MUGS
cd MUGS
git clone [email protected]:Raku-MUGS/MUGS-Core.git
git clone [email protected]:Raku-MUGS/MUGS-Games.git
git clone [email protected]:Raku-MUGS/MUGS-UI-Pop.git
cd MUGS-Core
zef install --exclude="pq:ver<5>:from<native>" .
mugs-admin create-universe
cd ../MUGS-Games
zef install .
cd ../MUGS-UI-Pop
zef install --deps-only . # Or skip --deps-only if you prefer
### LOCAL PLAY
# Play games using a local Pop UI, using an internal stub server and ephemeral data
mugs-pop
# Play games using an internal stub server accessing the long-lived data set
mugs-pop --universe=<universe-name> # 'default' if set up as above
# Log in and play games on a WebSocket server using a local Pop UI
mugs-pop --server=<host>:<port>
### GAME SERVERS
# Start a TLS WebSocket game server on localhost:10000 using fake certs
mugs-ws-server
# Specify a different MUGS identity universe (defaults to "default")
mugs-ws-server --universe=other-universe
# Start a TLS WebSocket game server on different host:port
mugs-ws-server --host=<hostname> --port=<portnumber>
# Start a TLS WebSocket game server using custom certs
mugs-ws-server --private-key-file=<path> --certificate-file=<path>
# Write a Log::Timeline JSON log for the WebSocket server
LOG_TIMELINE_JSON_LINES=log/mugs-ws-server mugs-ws-server
NOTE: See the top-level MUGS repo for more info.
MUGS::UI::Pop is a Pop/SDL app (mugs-pop
) and a growing set of UI plugins to play games in MUGS-Core and MUGS-Games via the Pop UI toolkit.
This early version only contains very limited modules and plugins, is missing significant functionality, and should not be considered "fully released" in the same way that the CLI and WebSimple UIs are.
MUGS is still in its infancy, at the beginning of a long and hopefully very enjoyable journey. There is a draft roadmap for the first few major releases but I don't plan to do it all myself -- I'm looking for contributions of all sorts to help make it a reality.
Please do! :-)
In all seriousness, check out the CONTRIBUTING doc (identical in each repo) for details on how to contribute, as well as the Coding Standards doc for guidelines/standards/rules that apply to code contributions in particular.
The MUGS project has a matching GitHub org, Raku-MUGS, where you will find all related repositories and issue trackers, as well as formal meta-discussion.
More informal discussion can be found on IRC in Libera.Chat #mugs.
Geoffrey Broadwell [email protected] (japhb on GitHub and Libera.Chat)
Copyright 2021 Geoffrey Broadwell
MUGS is free software; you can redistribute it and/or modify it under the Artistic License 2.0.