diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml new file mode 100644 index 0000000..e228aab --- /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 0000000..8b473ed --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,45 @@ +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("esv") + + metadata { + inceptionYear.set("2007") + developers.set(listOf( + Developer("lennartcl", "Lennart Kats", "lclkats@gmail.com"), + Developer("Gohla", "Gabriel Konat", "gabrielkonat@gmail.com"), + Developer("hendrikvanantwerpen", "Hendrik van Antwerpen", "hendrik@van-antwerpen.net"), + Developer("maartje", "Maartje de Jonge", "maartjedejonge@gmail.com"), + Developer("oskar-van-rest", "Oskar van Rest", "oskarvanrest@gmail.com"), + )) + } + } + } +} diff --git a/org.metaborg.meta.lang.esv/build.gradle.kts b/org.metaborg.meta.lang.esv/build.gradle.kts index 424cc32..baa750e 100644 --- a/org.metaborg.meta.lang.esv/build.gradle.kts +++ b/org.metaborg.meta.lang.esv/build.gradle.kts @@ -14,6 +14,7 @@ spoofaxLanguageSpecification { addSpoofaxCoreDependency.set(false) addSpoofaxRepository.set(false) } + dependencies { api(platform(libs.metaborg.platform)) { version { require("latest.integration") } } diff --git a/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 0000000..4576259 --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,21 @@ +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.metaborg.meta.lang.esv")