From 3846718bb1a33c7a74df58b8d506a90fe53b7db8 Mon Sep 17 00:00:00 2001 From: "Daniel A. A. Pelsmaeker" Date: Thu, 25 Jul 2024 02:23:39 +0200 Subject: [PATCH] Make repo build standalone --- .github/workflows/build.yaml | 36 +++++++++++++++++++++++++++ build.gradle.kts | 47 ++++++++++++++++++++++++++++++++++++ settings.gradle.kts | 23 ++++++++++++++++++ 3 files changed, 106 insertions(+) create mode 100644 .github/workflows/build.yaml create mode 100644 build.gradle.kts create mode 100644 settings.gradle.kts diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml new file mode 100644 index 00000000..e228aab2 --- /dev/null +++ b/.github/workflows/build.yaml @@ -0,0 +1,36 @@ +--- +name: 'Build & Publish' + +on: # yamllint disable-line rule:truthy + push: + pull_request: + branches: + - master + +jobs: + build: + uses: metaborg/actions/.github/workflows/gradle-build-matrix.yaml@main + publish-snapshot: + uses: metaborg/actions/.github/workflows/gradle-publish.yaml@main + with: + gradle-command: | + gradle :publish -Pgitonium.isSnapshot=true + gradle-version-command: | + gradle -q :printVersion -Pgitonium.isSnapshot=true + if: "github.event_name == 'push' && github.ref == 'refs/heads/master'" + needs: [build] + secrets: + METABORG_ARTIFACTS_USERNAME: ${{ secrets.METABORG_ARTIFACTS_USERNAME }} + METABORG_ARTIFACTS_PASSWORD: ${{ secrets.METABORG_ARTIFACTS_PASSWORD }} + publish-release: + uses: metaborg/actions/.github/workflows/gradle-publish.yaml@main + with: + gradle-command: | + gradle :publish + gradle-version-command: | + gradle -q :printVersion + if: "github.event_name == 'push' && startsWith(github.ref, 'refs/tags/release-')" + needs: [build] + secrets: + METABORG_ARTIFACTS_USERNAME: ${{ secrets.METABORG_ARTIFACTS_USERNAME }} + METABORG_ARTIFACTS_PASSWORD: ${{ secrets.METABORG_ARTIFACTS_PASSWORD }} diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 00000000..01eade30 --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,47 @@ +import org.metaborg.convention.Developer +import org.metaborg.convention.MavenPublishConventionExtension + +// Workaround for issue: https://youtrack.jetbrains.com/issue/KTIJ-19369 +@Suppress("DSL_SCOPE_VIOLATION") +plugins { + id("org.metaborg.convention.root-project") + alias(libs.plugins.gitonium) + alias(libs.plugins.spoofax.gradle.langspec) apply false +} + +rootProjectConvention { + // Add `publishAll` and `publish` tasks that delegate to the subprojects and included builds. + registerPublishTasks.set(true) +} + +allprojects { + apply(plugin = "org.metaborg.gitonium") + + // Configure Gitonium before setting the version + gitonium { + mainBranch.set("master") + } + + version = gitonium.version + group = "org.metaborg.devenv" + + pluginManager.withPlugin("org.metaborg.convention.maven-publish") { + extensions.configure(MavenPublishConventionExtension::class.java) { + repoOwner.set("metaborg") + repoName.set("mb-rep") + + metadata { + inceptionYear.set("2006") + developers.set(listOf( + Developer("Gohla", "Gabriel Konat", "gabrielkonat@gmail.com"), + Developer("lennartcl", "Lennart Kats", "lclkats@gmail.com"), + Developer("adilakhter", "Adil Akhter", "md.adilakhter@gmail.com"), + Developer("karltk", "Karl Trygve Kalleberg", "karltk@gmail.com"), + Developer("hendrikvanantwerpen", "Hendrik van Antwerpen", "hendrik@van-antwerpen.net"), + Developer("Apanatshka", "Jeff Smits", "mail@jeffsmits.net"), + Developer("Virtlink", "Daniel A. A. Pelsmaeker", "developer@pelsmaeker.net"), + )) + } + } + } +} diff --git a/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 00000000..1308c07c --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,23 @@ +rootProject.name = "esv-project" + +dependencyResolutionManagement { + repositories { + maven("https://artifacts.metaborg.org/content/groups/public/") + mavenCentral() + } +} + +pluginManagement { + repositories { + maven("https://artifacts.metaborg.org/content/groups/public/") + gradlePluginPortal() + } +} + +plugins { + id("org.metaborg.convention.settings") version "latest.integration" +} + +include("org.spoofax.terms") +include("org.spoofax.interpreter.library.index") +