Creates and compiles GGP js/html projects
Project description
Toolchain for writing General Game Players
This simple script allows you to build
and organize sophisticated general game playing (GGP)
projects. Currently, players are defined by a single .html
file,
which means that projects are either confined to a single file
or require a lot of tedious, error-prone manual copy-and-paste if functionality
is spread across different files.
This script allows you to define only the functionality
for the player that you are creating, avoiding all the boilerplate
and copying and pasting. It also allows you to manage larger projects
by generating an html
file from a template and (potentially multiple)
javascript files.
Setup
Make sure you have python and pip installed. Then run the following in a terminal:
pip install ggp-template
Usage
To create a new player from the sample template, run
python -m ggp.new new myplayer.js
To build an HTML file from a player, run
python -m ggp.make myplayer.js --ident=your_identifier
You can build multiple javascript files by simply passing multiple arguments (no dependency resolution is done; the scripts are added to the HTML file in the order they are passed in):
python ggp.make lib.js myplayer.js --ident=your_identifier
Options
The make
subcommand takes the following options:
template
The template HTML file to use (defaults to sample.html)ident
The identifier for your playerstrategy
The strategy name that is displayed on the pagetitle
The title for the page (defaults to the strategy and identifier)out
The html file to write to (defaults to stdout)
While javascript files are converted to data:text,
(hence URI encoded),
none of the other parameters are escaped. Therefore,
if the title
contains valid HTML, it will simply be inserted into the HTML
file without any extra escaping.
Recommendations
Most editors will allow you to set up a custom build
command. In vscode, for example, you can create a tasks.json
file in the project directory and set this to be the default
build task as described here.
If you want more sophisticated tooling, such as automatic dependency resolution
or compiling from e.g. Typescript, use webpack
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for ggp_template-0.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2bd8732b6a1dff1edebbf70a209e7b4b37f0e1849b6d29f9d9f20e90ff043126 |
|
MD5 | 8a698611b97567293f9cee312b0bf997 |
|
BLAKE2b-256 | 23bcc6ed300256abed3dda879b823c80cc3054a16f750f6c113db23de47429d3 |