---
title: Restricting sourcehut builds to a specific branch
author: Bob Rubbens
publish_timestamp: 2024-11-24T12:11:00+01:00
modified_timestamp: 2024-11-24T12:11:30+01:00
state: published
template: post.mako
id: c924bbc1-90c4-4671-9344-d5bfbac2b4b1
---

I've been using [sourcehut builds](https://builds.sr.ht/) to build and deploy this blog. One of sourcehut builds' primary characteristics is simplicity, in the positive sense. The benefits of being simple are many, but in particular, I like that it is easy to projects up and running, there's not that much documentation to read, and the website is clear and snappy. 

Obviously, simplicity also has its downsides, for example, it is hard to also be full-featured. In this case, it means that I have to roll up my sleeves to get something done.

The requirement I ran into was that I only want the `main` branch of my blog repo to be deployed to my website. Other CI services, like [GitLab CI/CD](https://docs.gitlab.com/ee/ci/yaml/index.html#rulesif) and [GitHub Actions](https://docs.github.com/en/actions/writing-workflows/workflow-syntax-for-github-actions#jobsjob_idif), have facilities for this in their respective YAML DSLs. Sourcehut encourages you to "just" use the shell, so I cobbled together the following:

```yaml {.numberLines .code}
# ... rest of .build.yml omitted ...
tasks:
- main-only: |
      cd unit-propagation-blog
      CURRENT_COMMIT=$(git rev-parse HEAD)
      MAIN_COMMIT=$(git show-ref --hash refs/heads/main)
      if [[ "$CURRENT_COMMIT" != "$MAIN_COMMIT" ]]
      then
        echo "Skipping build for non-main branch"
        complete-build
      fi
```
Simple enough: get the current checked out commit, and the commit of the main branch. Then only continue if they are equal.

The only non-standard bash function I'm using here is `complete-build`. This can be used to tell the sourcehut build VM that the current job is finished, and that other tasks from this job do not have to be executed. It is [intentionally undocumented](https://lists.sr.ht/~sircmpwn/sr.ht-dev/%3C20211025163408.26882-1-nico@bounga.org%3E#%3C20211025163408.26882-1-nico@bounga.org%3E+builds.sr.ht/manifest.md), so there's no guarantee this will keep working in the future. For a small side-project, I don't mind.

You might have noticed that this piece of shell code actually has a subtle problem: if you create another branch off `main`, the build script will actually run for that branch as well. Unless you immediately make a new commit on the new branch. I have not yet found a workaround, as sourcehut builds does not provide the actual branch name that triggered the build. My static site generator is deterministic, so the only problem here is that there might be superfluous deployments to the website. The site is still pretty lightweight, so I don't mind for now.