Skip to content

Commit

Permalink
[WIP] Meson build system
Browse files Browse the repository at this point in the history
  • Loading branch information
amezin committed Jan 21, 2024
1 parent 2a8d1ef commit 9e6d40c
Show file tree
Hide file tree
Showing 58 changed files with 918 additions and 715 deletions.
3 changes: 3 additions & 0 deletions .github/faketty.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#!/bin/bash

exec script -q -e -c "stty cols 80; $(printf "%q " "$@")"
4 changes: 2 additions & 2 deletions .github/problem-matchers/generic.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"owner": "generic",
"pattern": [
{
"regexp": "^([^\\s:]+):(\\d+)(?::(\\d+))?:?\\s+(?:((?i)warning|error):?)?\\s*(.+)$",
"regexp": "^(?:\\.\\./)?([^\\s:]+):(\\d+)(?::(\\d+))?:?\\s+(?:((?i)warning|error):?)?\\s*(.+)$",
"file": 1,
"line": 2,
"column": 3,
Expand All @@ -17,7 +17,7 @@
"owner": "generic-nolocation",
"pattern": [
{
"regexp": "^(?:([^\\s:]+):?\\s+)?((?i)warning|error):?\\s*(.+)$",
"regexp": "^(?:\\.\\./)?(?:([^\\s:]+):?\\s+)?((?i)warning|error):?\\s*(.+)$",
"file": 1,
"severity": 2,
"message": 3
Expand Down
2 changes: 1 addition & 1 deletion .github/problem-matchers/gettext-stats.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
"severity": "warning",
"pattern": [
{
"regexp": "msgfmt .* --statistics .* (po/.*\\.po)",
"regexp": "(?:^|\\s)(?:\\.\\./)?(locale/.*\\.po)$",
"file": 1
},
{
Expand Down
38 changes: 24 additions & 14 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ on:
env:
FORCE_COLOR: 1
PIP_DISABLE_PIP_VERSION_CHECK: 1
TERM: xterm-color

defaults:
run:
Expand Down Expand Up @@ -57,15 +58,15 @@ jobs:

- name: Install JS dependencies
id: npm
run: npm ci
run: npm install
if: ${{ always() && steps.checkout.conclusion == 'success' }}

- name: Enable eslint error matcher
run: echo "::add-matcher::.github/problem-matchers/eslint-stylish.json"
if: ${{ always() && steps.checkout.conclusion == 'success' }}

- name: Lint JS code
run: make "ESLINT_OPTS=--format .github/eslint-formatter.js" lint
run: npm run-script lint -- --format .github/eslint-formatter.js
if: ${{ always() && steps.npm.conclusion == 'success' }}
env:
FORCE_COLOR: 0
Expand Down Expand Up @@ -97,17 +98,25 @@ jobs:
run: echo "::add-matcher::.github/problem-matchers/generic.json"
if: ${{ always() && steps.checkout.conclusion == 'success' }}

- name: Compile GSettings schemas
run: make schemas 2>&1 | tee schemas.log
- id: meson-setup
name: Prepare build directory
run: .github/faketty.sh meson setup build
if: ${{ always() && steps.checkout.conclusion == 'success' }}

- name: Validate .desktop file
run: make desktop-file-validate 2>&1 | tee desktop-file.log
if: ${{ always() && steps.checkout.conclusion == 'success' }}
- name: Run glib-compile-schemas checks
run: ../.github/faketty.sh meson test -v -j1 --no-rebuild --suite glib-compile-schemas --logbase glib-compile-schemas
working-directory: build
if: ${{ always() && steps.meson-setup.conclusion == 'success' }}

- name: Validate Gtk .ui files
run: xvfb-run make gtk-builder-validate 2>&1 | tee gtk-builder.log
if: ${{ always() && steps.checkout.conclusion == 'success' }}
- name: Run desktop-file-validate checks
run: ../.github/faketty.sh meson test -v -j1 --suite desktop-file-validate --logbase desktop-file-validate
working-directory: build
if: ${{ always() && steps.meson-setup.conclusion == 'success' }}

- name: Run gtk-builder-validate checks
run: xvfb-run ../.github/faketty.sh meson test -v -j1 --suite gtk-builder-validate --logbase gtk-builder-validate
working-directory: build
if: ${{ always() && steps.meson-setup.conclusion == 'success' }}

- name: Ensure Python requirements .txt files are in sync with .in files
run: |
Expand All @@ -126,19 +135,20 @@ jobs:
if: ${{ always() && steps.checkout.conclusion == 'success' }}

- name: Upload reports to Testspace
run: testspace --verbose eslint.xml "*.log{lint}"
run: testspace --verbose eslint.xml "*.log{lint}" "build/meson-logs/*.txt{lint}"
if: ${{ always() && steps.setup_testspace.outcome == 'success' }}

- name: Build extension package
id: pack
run: xvfb-run make pack
if: ${{ always() && steps.checkout.conclusion == 'success' }}
run: xvfb-run ninja -j1 pack
working-directory: build
if: ${{ always() && steps.meson-setup.conclusion == 'success' }}

- name: Upload extension package as artifact
id: upload
uses: actions/upload-artifact@v4
with:
name: pack
path: "*.shell-extension.zip"
path: "build/*.shell-extension.zip"
if-no-files-found: error
if: ${{ always() && steps.pack.conclusion == 'success' }}
22 changes: 11 additions & 11 deletions .github/workflows/check-po.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ on:

env:
FORCE_COLOR: 1
PIP_DISABLE_PIP_VERSION_CHECK: 1

defaults:
run:
Expand All @@ -27,7 +26,7 @@ jobs:
echo -n linguas= >>$GITHUB_OUTPUT
grep -Ev '^\s*#.*' LINGUAS | jq -Rcn '[inputs | scan("\\S+")]' >>$GITHUB_OUTPUT
shell: bash
working-directory: po
working-directory: locale

check:
needs: configure
Expand All @@ -43,25 +42,26 @@ jobs:

steps:
- name: Checkout
id: checkout
uses: actions/checkout@v4

- run: git config --global --replace-all safe.directory "$GITHUB_WORKSPACE"

- name: Enable gettext stats problem matcher
run: echo "::add-matcher::.github/problem-matchers/gettext-stats.json"

- name: Enable generic problem matcher
run: echo "::add-matcher::.github/problem-matchers/generic.json"

- name: Enable gettext stats problem matcher
run: echo "::add-matcher::.github/problem-matchers/gettext-stats.json"

- name: Compile translation
run: make msgfmt/${{ matrix.lang }} 2>&1 | tee $GITHUB_STEP_SUMMARY
run: |
echo locale/${{ matrix.lang }}.po
msgfmt --check -v -o /dev/null locale/${{ matrix.lang }}.po 2>&1 | tee $GITHUB_STEP_SUMMARY
shell: bash

- name: Disable gettext stats problem matcher
run: echo "::remove-matcher owner=gettext-stats::"

- name: Ensure .po file is in sync with .pot
run: |
touch po/*.pot # Make sure .pot won't be re-generated
make msgcmp/${{ matrix.lang }} 2>&1
if: ${{ always() && steps.checkout.conclusion == 'success' }}
run: msgcmp --use-untranslated --use-fuzzy locale/${{ matrix.lang }}.po locale/*.pot
shell: bash
if: ${{ always() && steps.meson-setup.conclusion == 'success' }}
77 changes: 49 additions & 28 deletions .github/workflows/pot.yml
Original file line number Diff line number Diff line change
@@ -1,20 +1,30 @@
concurrency:
group: ${{ github.workflow }}/${{ github.ref }}

name: pot

on:
workflow_dispatch:
inputs:
commit:
description: Commit changes
required: false
default: false
type: boolean

workflow_call:
push:
branches:
- master
paths-ignore:
- docs/**
- po/*.po
- README.md
- Vagrantfile
- vagrant-provision/**
inputs:
commit:
description: Commit changes
required: false
default: false
type: boolean
secrets:
APP_ID:
description: 'ID of the committer application'
required: false
APP_KEY:
description: 'Private key of the committer application'
required: false

env:
FORCE_COLOR: 1
TERM: xterm-color

jobs:
pot:
Expand All @@ -23,41 +33,52 @@ jobs:
image: ghcr.io/ddterm/ci-docker-image:2024.01.21.0

steps:
- name: Get app token
id: app-token
uses: actions/create-github-app-token@v1
with:
app-id: ${{ secrets.APP_ID }}
private-key: ${{ secrets.APP_KEY }}

- name: Checkout
uses: actions/checkout@v4
with:
token: ${{ steps.app-token.outputs.token }}

- run: git config --global --replace-all safe.directory "$GITHUB_WORKSPACE"

- name: Enable generic error matcher
run: echo "::add-matcher::.github/problem-matchers/generic.json"

- name: Update .pot files
run: po/update-pot.sh
- name: Prepare build directory
run: .github/faketty.sh meson setup build

- name: Update POTFILES.in
run: ninja -j1 potfiles
working-directory: build

- name: Update .pot file
run: ninja -j1 msgmerge
working-directory: build

- name: Update .po files
run: for pofile in *.po; do msgmerge --update --previous "$pofile" *.pot; done
working-directory: po

- name: Stage changes
run: git add po/*.po po/*.pot
run: git add po/*.po po/*.pot po/POTFILES.in

- name: Check if there are any changes
id: diff
uses: actions/github-script@v7
with:
result-encoding: string
script: |
const { stdout } = await exec.getExecOutput('git', ['diff', '--cached']);
const { stdout } = await exec.getExecOutput('git', ['diff', '--cached', '--ignore-matching-lines=^"POT-Creation-Date: ']);
return stdout.trim();
- name: Get commit token
id: app-token
uses: actions/create-github-app-token@v1
with:
app-id: ${{ secrets.APP_ID }}
private-key: ${{ secrets.APP_KEY }}
if: inputs.commit

- name: Commit
uses: ddterm/github-api-commit-action@ccf9b520c5698380ad3b9619c5add427369b7ef1
if: steps.diff.outputs.result != ''
with:
token: ${{ steps.app-token.outputs.token }}
commit-message: 'Update translation files'
if: inputs.commit && steps.diff.outputs.result
11 changes: 10 additions & 1 deletion .github/workflows/pr.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,10 @@ on:
pull_request:
paths-ignore:
- docs/**
- po/**
- po/*.po
- po/*.pot
- po/POTFILES
- po/POTFILES.in
- README.md
- Vagrantfile
- vagrant-provision/**
Expand All @@ -24,3 +27,9 @@ jobs:
test:
needs: build
uses: ./.github/workflows/test.yml

translations:
uses: ./.github/workflows/pot.yml
with:
commit: false
secrets: inherit
11 changes: 10 additions & 1 deletion .github/workflows/push.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,10 @@ on:
- v*
paths-ignore:
- docs/**
- po/**
- po/*.po
- po/*.pot
- po/POTFILES
- po/POTFILES.in
- README.md
- Vagrantfile
- vagrant-provision/**
Expand All @@ -26,3 +29,9 @@ jobs:
test:
needs: build
uses: ./.github/workflows/test.yml

translations:
uses: ./.github/workflows/pot.yml
with:
commit: ${{ github.ref_type == 'branch' && github.ref_name == github.event.repository.default_branch }}
secrets: inherit
2 changes: 1 addition & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ jobs:
- name: Check version matches the tag
run: |
test "v$(jq .version metadata.json.in)" = "${{ github.ref_name }}"
test "v$(meson rewrite kwargs info project / 2>&1 | jq -r '.kwargs."project#/".version')" = "${{ github.ref_name }}"
- name: Bump version
run: |
Expand Down
13 changes: 1 addition & 12 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,17 +1,6 @@
*~
/node_modules/

# Makefile output
/*.shell-extension.zip
/ddterm/pref/ui/
/ddterm/com.github.amezin.ddterm.desktop
/ddterm/com.github.amezin.ddterm.desktop.in
/ddterm/com.github.amezin.ddterm.service
/metadata.json
/schemas/gschemas.compiled
/locale/
/tmp/
/revision.txt
/node_modules/

# do-in-docker.sh/do-in-podman.sh
/.container-home/
Expand Down
Loading

0 comments on commit 9e6d40c

Please sign in to comment.