Skip to content

Latest commit

 

History

History
56 lines (40 loc) · 3.23 KB

README.adoc

File metadata and controls

56 lines (40 loc) · 3.23 KB

godot-ci-template

This is a Godot 4 template based on the excellent abarichello/godot-ci repository, with a number of enhancements:

  • It’s a template, so you can just instance it superfast 🚀

  • It’s optimized for web builds and GitHub Pages, though other platforms can be easily enabled in the GitHub Actions configuration.

  • It runs builds and deploys in separate steps. It’s configured so that the deploy steps are skipped on non-mainline branches.

  • Uh, it comes with a really spiffy ClickyClicker demo app I made in like, an hour. You can play it here.

Usage

  1. Create a new repository from the template. Can be private or public, but GitHub Pages only works with public repositories (and Enterprise ones).

  2. Delete the clicky-clicker directory and replace it with your own new Godot project. Update the corresponding environment variables at the top of .github/workflows/godot-ci.yml.

  3. Replace the LICENSE.

  4. Have fun!

Setting up GitHub Pages

The GitHub template only sets up the actual repository for you and not any of the settings. To enable GitHub Pages, which you’ll need if you want to play your web export on GitHub, you’ll need to do two things:

  1. Ensure your repository is public. This is a bit unfortunate, but the cost of using GitHub I suppose. If not already a public repository, go to Settings, then at the bottom of the General subtab, click the red Change visibility button and change to public.

  2. Still on the Settings tab, go to the Pages subtab, then ensure you’re publishing, Source: Deploy from a branch, Branch: gh-pages / (root).

You may need to push another change, but after that, you should be able to access your game at the URL at the top of the Pages subtab.

Publishing to itch.io (assuming web)

  1. Create your game (draft is fine) on itch.io.

  2. Configure your game, at least setting Kind of project to HTML:

    itch project setting
  3. Follow the directions here to get your itch.io Butler API key.

  4. Follow the directions here to create a GitHub secret in your repository called BUTLER_API_KEY containing the API key you got from the previous step. New repository secret is fine.

  5. Update your godot-ci.yml environment variables to at least refer to your itch.io project name.

  6. Commit that, push it, and wait for it to succeed.

  7. Once it succeeds, head back to your itch.io project page and ensure This file will be played in the browser is checked.

    itch upload setting
  8. Finally, make sure your Embed options look like the following, especially the SharedArrayBuffer support setting:

    itch embed setting

    And…​that should be it.

C#/Mono/.NET?

Godot 4, at least 4.2, doesn’t support web, so that’s left out of this template.