Site templates are configured in etc/config/site-templates.yaml
.
The configuration is a list of site templates each having a name and a raw configuration string. Use the following steps to create the configuration string:
- Compiler Explorer and configure the setup you want to export as a template
- Click the "Share" dropdown in the top-right corner of the page
- Select the "Copy full link" option
- Strip the "https://godbolt.org/#" prefix from the link
- Paste the configuration string into your new entry in the templates list.
After you have created a new site template, you can generate screenshots using Puppeteer.
Below are instructions to generate site templates. Because it's a bit hacky feel free to not run the script, we can do so when a PR is made.
Site template screenshots are generated with a hacky script located at
etc/scripts/generate_site_template_screenshots.ts
.
To run the script, cd
to the etc/scripts/
directory and run
npm i puppeteer --no-save && npx node --no-warnings=ExperimentalWarning --import=tsx generate_site_template_screenshots.ts
The script uses puppeteer and chrome to generate screenshots. The script will take a little while to run as it generates multiple screenshots per template and gives pages ample time to load.
Screenshots are located in views/resources/template_screenshots/
. The
script won't regenerate everything by default, to regenerate delete the screenshot images you want deleted.