diff options
| author | Xiaotian Wu <[email protected]> | 2025-05-21 17:31:55 +0800 | 
|---|---|---|
| committer | Oz Tiram <[email protected]> | 2025-05-26 08:34:20 +0200 | 
| commit | a9fb14f6947da649fc7acd00a5383bb3f73435a2 (patch) | |
| tree | cb1480e6f58ba14215fb929f076bca9d56655f06 | |
| parent | b78ac59b1e0d7d90e39ae89a6cb62b492e89a807 (diff) | |
| download | pluma-a9fb14f6947da649fc7acd00a5383bb3f73435a2.tar.bz2 pluma-a9fb14f6947da649fc7acd00a5383bb3f73435a2.tar.xz | |
Try to use github action
| -rw-r--r-- | .github/dependabot.yml | 8 | ||||
| -rwxr-xr-x | .github/workflows/archlinux.sh | 49 | ||||
| -rwxr-xr-x | .github/workflows/builds.sh | 65 | ||||
| -rw-r--r-- | .github/workflows/builds.yml | 94 | ||||
| -rwxr-xr-x | .github/workflows/debian.sh | 47 | ||||
| -rwxr-xr-x | .github/workflows/fedora.sh | 40 | ||||
| -rwxr-xr-x | .github/workflows/mate-desktop.sh | 146 | ||||
| -rw-r--r-- | .github/workflows/release.yml | 39 | ||||
| -rwxr-xr-x | .github/workflows/ubuntu.sh | 49 | 
9 files changed, 537 insertions, 0 deletions
| diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 00000000..80851cd3 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,8 @@ +# Enable dependabot to keep our GHA pins automatically +# updated, so we don't fall too far behind in the future +version: 2 +updates: +  - package-ecosystem: github-actions +    directory: "/" +    schedule: +      interval: weekly diff --git a/.github/workflows/archlinux.sh b/.github/workflows/archlinux.sh new file mode 100755 index 00000000..7d12dd36 --- /dev/null +++ b/.github/workflows/archlinux.sh @@ -0,0 +1,49 @@ +#!/usr/bin/bash + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Required packages on Archlinux +requires=( +	ccache # Use ccache to speed up build +	clang  # Build with clang on Archlinux +	meson  # Used for meson build +) + +# https://gitlab.archlinux.org/archlinux/packaging/packages/pluma +requires+=( +	appstream-glib +	autoconf-archive +	clang +	dconf +	enchant +	file +	gcc +	git +	glib2-devel +	gobject-introspection +	gtksourceview4 +	iso-codes +	itstool +	libpeas +	libsm +	libx11 +	make +	mate-common +	python +	which +	yelp-tools +) + +infobegin "Update system" +pacman --noconfirm -Syu +infoend + +infobegin "Install dependency packages" +pacman --noconfirm -S ${requires[@]} +infoend diff --git a/.github/workflows/builds.sh b/.github/workflows/builds.sh new file mode 100755 index 00000000..8338709a --- /dev/null +++ b/.github/workflows/builds.sh @@ -0,0 +1,65 @@ +#!/usr/bin/bash + +set -e +set -o pipefail + +CPUS=$(grep processor /proc/cpuinfo | wc -l) + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Run meson first, then run autotools +# Because meson dist requires a clean git workspace +# Autotools will modify some files (such as po, etc.), making them dirty. +if [ -f meson.build ]; then + +	infobegin "Configure (meson)" +	meson setup _build --prefix=/usr +	infoend + +	infobegin "Build (meson)" +	meson compile -C _build +	infoend + +	infobegin "Test (meson)" +	ninja -C _build test +	infoend + +	infobegin "Dist (meson)" +	# Git safedirectory stop ninja dist +	# https://github.com/git/git/commit/8959555cee7ec045958f9b6dd62e541affb7e7d9 +	# https://git-scm.com/docs/git-config/2.35.2#Documentation/git-config.txt-safedirectory +	git config --global --add safe.directory ${PWD} +	ninja -C _build dist +	infoend +fi + +if [ -f autogen.sh ]; then +	infobegin "Configure (autotools)" +	NOCONFIGURE=1 ./autogen.sh +	./configure --prefix=/usr --enable-compile-warnings=maximum || { +		cat config.log +		exit 1 +	} +	infoend + +	infobegin "Build (autotools)" +	make -j ${CPUS} +	infoend + +	infobegin "Check (autotools)" +	make -j ${CPUS} check || { +		# Settings schema 'org.mate.pluma' is not installed +		true +	} +	infoend + +	infobegin "Distcheck (autotools)" +	make -j ${CPUS} distcheck +	infoend +fi diff --git a/.github/workflows/builds.yml b/.github/workflows/builds.yml new file mode 100644 index 00000000..4387c97c --- /dev/null +++ b/.github/workflows/builds.yml @@ -0,0 +1,94 @@ +name: CI Build + +on: +  push: +    branches: +      - master +  pull_request: +    branches: +      - master +  workflow_dispatch: + +# cancel already running builds of the same branch or pull request +concurrency: +  group: ci-${{ github.workflow }}-${{ github.event.pull_request.number || github.head_ref || github.sha }} +  cancel-in-progress: true + +env: +  MATE_DESKTOP_VERSION: 1.28.2 +  CACHE_PATH: /tmp/.cache + +jobs: +  build: +    name: Build on ${{matrix.container}} (using ${{matrix.cc}}) +    runs-on: ubuntu-latest +    container: +      image: ${{matrix.container}} +      volumes: +        - /tmp/.cache +        - /var/cache/apt + +    strategy: +      fail-fast: false # don't cancel other jobs in the matrix if one fails +      matrix: +        container: +          [ +            "debian:testing", +            "fedora:latest", +            "ubuntu:rolling", +            "archlinux:latest", +          ] +        cc: ["gcc"] +        cxx: ["g++"] +        include: +          - container: "archlinux:latest" +            cc: "clang" +            cxx: "clang++" + +    env: +      # Speed up build with ccache +      CC: ccache ${{ matrix.cc }} +      CXX: ccache ${{ matrix.cxx }} +      CONTAINER: ${{ matrix.container }} + +    steps: +      - name: Setup environment variables +        id: distro-name +        shell: bash +        run: | +          split=(${CONTAINER//:/ }) +          distro=${split[0]} +          short_sha=${SHA:0:8} +          echo "DISTRO=$distro" | tee -a  $GITHUB_ENV +      - name: Install git command +        shell: bash +        run: | +          echo "::group::Install git ..." +          apt-get update -qq && apt-get install --assume-yes git || true +          dnf update -y && dnf install -y git || true +          pacman --noconfirm -Sy git || true +          echo "::endgroup::" +      - name: Repository checkout +        uses: actions/checkout@v4 +        with: +          submodules: "true" +      - name: Install dependency packages +        run: .github/workflows/${{ env.DISTRO }}.sh +      - name: Enable ccache to speed up builds +        uses: hendrikmuhs/[email protected] +        with: +          key: ${{ env.DISTRO }}-${{ matrix.cc }} + +      # INFO: M-C-C depends mate-desktop 1.27.1+, so we should install it from source. +      - name: Cache mate-desktop binary packages +        uses: actions/cache@v3 +        id: cache-mate-desktop +        with: +          path: ${{ env.CACHE_PATH }} +          key: ${{ env.DISTRO }}-build-mate-desktop-${{env.MATE_DESKTOP_VERSION}} +      - name: Built and install mate-desktop from source +        run: .github/workflows/mate-desktop.sh ${{env.MATE_DESKTOP_VERSION}} ${{ env.CACHE_PATH }} +      # INFO: M-C-C depends mate-desktop 1.27.1+, install finished. + +      - name: Build the source code +        run: .github/workflows/builds.sh diff --git a/.github/workflows/debian.sh b/.github/workflows/debian.sh new file mode 100755 index 00000000..100e8eda --- /dev/null +++ b/.github/workflows/debian.sh @@ -0,0 +1,47 @@ +#!/usr/bin/bash + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Required packages on Debian +requires=( +	ccache # Use ccache to speed up build +	meson  # Used for meson build +) + +# https://salsa.debian.org/debian-mate-team/pluma +requires+=( +	autopoint +	autoconf-archive +	gobject-introspection +	gtk-doc-tools +	gettext +	gla11y +	iso-codes +	libenchant-2-dev +	libgirepository1.0-dev +	libglib2.0-dev +	libgtk-3-dev +	libgtksourceview-4-dev +	libpeas-dev +	libsm-dev +	libx11-dev +	libxml2-dev +	mate-common +	yelp-tools +) + +infobegin "Update system" +apt-get update -qq +infoend + +infobegin "Install dependency packages" +env DEBIAN_FRONTEND=noninteractive \ +	apt-get install --assume-yes \ +	${requires[@]} +infoend diff --git a/.github/workflows/fedora.sh b/.github/workflows/fedora.sh new file mode 100755 index 00000000..a433fc07 --- /dev/null +++ b/.github/workflows/fedora.sh @@ -0,0 +1,40 @@ +#!/usr/bin/bash + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Required packages on Fedora +requires=( +	ccache # Use ccache to speed up build +	meson  # Used for meson build +) + +# https://src.fedoraproject.org/cgit/rpms/pluma.git +requires+=( +	desktop-file-utils +	enchant-devel +	gtk3-devel +	gtksourceview4-devel +	iso-codes-devel +	libSM-devel +	libpeas1-devel +	make +	mate-common +	mate-desktop-devel +	python3-devel +	python3-gobject-base +	python3-setuptools +) + +infobegin "Update system" +dnf update -y +infoend + +infobegin "Install dependency packages" +dnf install -y ${requires[@]} +infoend diff --git a/.github/workflows/mate-desktop.sh b/.github/workflows/mate-desktop.sh new file mode 100755 index 00000000..f4b5fe62 --- /dev/null +++ b/.github/workflows/mate-desktop.sh @@ -0,0 +1,146 @@ +#!/usr/bin/bash + +set -e +set -o pipefail + +NAME="mate-desktop" +TEMP_DIR=$(mktemp -d) +OS=$(cat /etc/os-release | grep ^ID | head -n 1 | awk -F= '{ print $2}') +TAG=$1 +CACHE_DIR=$2 + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Required packages to build mate-desktop +# https://gitlab.archlinux.org/archlinux/packaging/packages/mate-desktop +arch_requires=( +	autoconf-archive +	gobject-introspection +	mate-common +	intltool +) + +# https://salsa.debian.org/debian-mate-team/mate-desktop/-/blob/master/debian/control +debian_requires=( +	autoconf-archive +	gobject-introspection +	gtk-doc-tools +	intltool +	iso-codes +	libdconf-dev +	libgdk-pixbuf-2.0-dev +	libgirepository1.0-dev +	libglib2.0-dev +	libglib2.0-doc +	libgtk-3-dev +	libgtk-3-doc +	librsvg2-bin +	libstartup-notification0-dev +	libx11-dev +	libxml2-dev +	libxrandr-dev +	mate-common +) + +# https://src.fedoraproject.org/rpms/mate-desktop/blob/rawhide/f/mate-desktop.spec +fedora_requires=( +	dconf-devel +	desktop-file-utils +	gobject-introspection-devel +	make +	mate-common +	startup-notification-devel +	gtk3-devel +	iso-codes-devel +	gobject-introspection-devel +	cairo-gobject-devel +) + +# https://git.launchpad.net/ubuntu/+source/mate-desktop/tree/debian/control +ubuntu_requires=( +	autoconf-archive +	gobject-introspection +	gtk-doc-tools +	intltool +	iso-codes +	libdconf-dev +	libgdk-pixbuf-2.0-dev +	libgirepository1.0-dev +	libglib2.0-dev +	libglib2.0-doc +	libgtk-3-dev +	libgtk-3-doc +	librsvg2-bin +	libstartup-notification0-dev +	libx11-dev +	libxml2-dev +	libxrandr-dev +	mate-common +) + +requires=$(eval echo '${'"${OS}_requires[@]}") + +infobegin "Install Depends for mate-desktop" +case ${OS} in +arch) +	pacman --noconfirm -Syu +	pacman --noconfirm -S ${requires[@]} +	;; +debian | ubuntu) +	apt-get update -qq +	env DEBIAN_FRONTEND=noninteractive \ +		apt-get install --assume-yes --no-install-recommends ${requires[@]} +	;; +fedora) +	dnf update -y +	dnf install -y ${requires[@]} +	;; +esac +infoend + +# Use cached packages first +if [ -f $CACHE_DIR/${NAME}-${TAG}.tar.xz ]; then +	echo "Found cache package, reuse it" +	tar -C / -Jxf $CACHE_DIR/${NAME}-${TAG}.tar.xz +else +	git clone --recurse-submodules https://github.com/mate-desktop/${NAME} + +	# Foldable output information +	infobegin "Configure" +	cd ${NAME} +	git checkout v${TAG} +	if [[ ${OS} == "debian" || ${OS} == "ubuntu" ]]; then +		./autogen.sh --prefix=/usr --libdir=/usr/lib/x86_64-linux-gnu --libexecdir=/usr/lib/x86_64-linux-gnu || { +			cat config.log +			exit 1 +		} +	else +		./autogen.sh --prefix=/usr || { +			cat config.log +			exit 1 +		} +	fi +	infoend + +	infobegin "Build" +	make -j ${JOBS} +	infoend + +	infobegin "Install" +	make install +	infoend + +	# Cache this package version +	infobegin "Cache" +	[ -d ${CACHE_DIR} ] || mkdir -p ${CACHE_DIR} +	make install DESTDIR=${TEMP_DIR} +	cd $TEMP_DIR +	tar -J -cf $CACHE_DIR/${NAME}-${TAG}.tar.xz * +	infoend +fi diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 00000000..615534ed --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,39 @@ +name: Release Version +on: +  push: +    tags: +      - "v*.*.*" + +env: +  MATE_DESKTOP_VERSION: 1.28.2 +  CACHE_PATH: /tmp/.cache + +jobs: +  release: +    name: Release New Version +    runs-on: ubuntu-latest +    steps: +      - name: Repository checkout +        uses: actions/checkout@v4 +        with: +          submodules: "true" + +      - name: Install dependency packages +        run: sudo .github/workflows/ubuntu.sh + +      - name: Install higher version Mate component packages +        run: sudo .github/workflows/mate-desktop.sh ${{env.MATE_DESKTOP_VERSION}} ${{ env.CACHE_PATH }} + +      - name: Build the source code +        run: .github/workflows/builds.sh autotools + +      - name: Install GH CLI +        uses: dev-hanz-ops/[email protected] +        with: +          gh-cli-version: 2.72.0 + +      - name: Create github release +        run: | +          gh release create ${{ github.ref_name }} --title ${{ github.ref_name }} --generate-notes pluma*.tar.xz +        env: +          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/ubuntu.sh b/.github/workflows/ubuntu.sh new file mode 100755 index 00000000..cb35281d --- /dev/null +++ b/.github/workflows/ubuntu.sh @@ -0,0 +1,49 @@ +#!/usr/bin/bash + +# Use grouped output messages +infobegin() { +	echo "::group::${1}" +} +infoend() { +	echo "::endgroup::" +} + +# Required packages on Ubuntu +requires=( +	ccache # Use ccache to speed up build +	meson  # Used for meson build +) + +# https://git.launchpad.net/ubuntu/+source/pluma/tree/debian/control +requires+=( +	autopoint +	autoconf-archive +	git +	gobject-introspection +	gtk-doc-tools +	iso-codes +	libenchant-2-dev +	libgirepository1.0-dev +	libglib2.0-dev +	libgtk-3-dev +	libgtksourceview-4-dev +	libpeas-dev +	libsm-dev +	libx11-dev +	libxml2-dev +	make +	mate-common +	python3-dev +	python3-lxml +	yelp-tools +) + +infobegin "Update system" +apt-get update -y +infoend + +infobegin "Install dependency packages" +env DEBIAN_FRONTEND=noninteractive \ +	apt-get install --assume-yes \ +	${requires[@]} +infoend | 
