mirror of
https://github.com/GayPizzaSpecifications/concrete.git
synced 2025-08-05 22:21:33 +00:00
Compare commits
25 Commits
Author | SHA1 | Date | |
---|---|---|---|
353f62dfc8
|
|||
e6f1efb346
|
|||
df8f755ff7
|
|||
0478616f34
|
|||
43d76cfb96
|
|||
0d60664838
|
|||
02abbabb08
|
|||
b040711701
|
|||
96ed2ff2bb
|
|||
061a788d93
|
|||
3c02e23163
|
|||
1c4217da53
|
|||
81985013e8
|
|||
55efba22bd
|
|||
2cb2d8fe89
|
|||
b3219afb24
|
|||
ac7ec227b0
|
|||
0ed243e9ae
|
|||
34648bdc8c
|
|||
e1e42df67e
|
|||
dc1ebe09b7
|
|||
1cd36b5529
|
|||
a06687507c
|
|||
5d4152d6df
|
|||
4c7dea2296
|
20
.github/workflows/portal.yml
vendored
Normal file
20
.github/workflows/portal.yml
vendored
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
name: Gradle Plugin Portal
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- 'v[0-9]+.[0-9]+.[0-9]+'
|
||||||
|
jobs:
|
||||||
|
publish:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
- name: Set up JDK 17
|
||||||
|
uses: actions/setup-java@v3
|
||||||
|
with:
|
||||||
|
java-version: '17'
|
||||||
|
distribution: 'temurin'
|
||||||
|
- name: Publish with Gradle
|
||||||
|
uses: gradle/gradle-build-action@v2
|
||||||
|
with:
|
||||||
|
arguments: "publishPlugins -Pgradle.publish.key=${{ secrets.GRADLE_PLUGIN_PUBLISHING_KEY }} -Pgradle.publish.secret=${{ secrets.GRADLE_PLUGIN_PUBLISHING_SECRET }}"
|
2
.github/workflows/publish.yml
vendored
2
.github/workflows/publish.yml
vendored
@ -4,7 +4,7 @@ on:
|
|||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
publish:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout Repository
|
- name: Checkout Repository
|
||||||
|
16
.github/workflows/qodona.yml
vendored
Normal file
16
.github/workflows/qodona.yml
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
name: Qodona
|
||||||
|
on: [push]
|
||||||
|
jobs:
|
||||||
|
scan:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
- name: Qodana Scan
|
||||||
|
uses: JetBrains/qodana-action@main
|
||||||
|
env:
|
||||||
|
QODANA_TOKEN: "${{ secrets.QODANA_TOKEN }}"
|
||||||
|
- name: Upload CodeQL SARIF
|
||||||
|
uses: github/codeql-action/upload-sarif@v2
|
||||||
|
with:
|
||||||
|
sarif_file: "${{ runner.temp }}/qodana/results/qodana.sarif.json"
|
@ -1,13 +1,15 @@
|
|||||||
|
@file:Suppress("UnstableApiUsage")
|
||||||
plugins {
|
plugins {
|
||||||
`kotlin-dsl`
|
`kotlin-dsl`
|
||||||
kotlin("plugin.serialization") version "1.7.10"
|
|
||||||
|
|
||||||
id("maven-publish")
|
`maven-publish`
|
||||||
id("java-gradle-plugin")
|
`java-gradle-plugin`
|
||||||
|
|
||||||
|
id("com.gradle.plugin-publish") version "1.1.0"
|
||||||
}
|
}
|
||||||
|
|
||||||
group = "gay.pizza.foundation"
|
group = "gay.pizza.foundation"
|
||||||
version = "0.7.0"
|
version = "0.12.0"
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
@ -15,8 +17,8 @@ repositories {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:1.7.10")
|
implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:1.8.10")
|
||||||
implementation("org.jetbrains.kotlin:kotlin-serialization:1.7.10")
|
implementation("org.jetbrains.kotlin:kotlin-serialization:1.8.10")
|
||||||
implementation("gradle.plugin.com.github.johnrengelman:shadow:7.1.2")
|
implementation("gradle.plugin.com.github.johnrengelman:shadow:7.1.2")
|
||||||
implementation("com.google.code.gson:gson:2.10.1")
|
implementation("com.google.code.gson:gson:2.10.1")
|
||||||
|
|
||||||
@ -25,29 +27,56 @@ dependencies {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gradlePlugin {
|
gradlePlugin {
|
||||||
|
website.set("https://github.com/GayPizzaSpecifications/concrete")
|
||||||
|
vcsUrl.set("https://github.com/GayPizzaSpecifications/concrete")
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
create("concrete-root") {
|
create("concrete-root") {
|
||||||
id = "gay.pizza.foundation.concrete-root"
|
id = "gay.pizza.foundation.concrete-root"
|
||||||
implementationClass = "gay.pizza.foundation.concrete.ConcreteRootPlugin"
|
implementationClass = "gay.pizza.foundation.concrete.ConcreteRootPlugin"
|
||||||
|
|
||||||
|
displayName = "Concrete Root"
|
||||||
|
description = "Gradle conventions for Foundation Bukkit plugins. Root project plugin."
|
||||||
}
|
}
|
||||||
|
|
||||||
create("concrete-base") {
|
create("concrete-base") {
|
||||||
id = "gay.pizza.foundation.concrete-base"
|
id = "gay.pizza.foundation.concrete-base"
|
||||||
implementationClass = "gay.pizza.foundation.concrete.ConcreteBasePlugin"
|
implementationClass = "gay.pizza.foundation.concrete.ConcreteBasePlugin"
|
||||||
|
|
||||||
|
displayName = "Concrete Base"
|
||||||
|
description = "Gradle conventions for Foundation Bukkit plugins. Base project plugin."
|
||||||
}
|
}
|
||||||
|
|
||||||
create("concrete-library") {
|
create("concrete-library") {
|
||||||
id = "gay.pizza.foundation.concrete-library"
|
id = "gay.pizza.foundation.concrete-library"
|
||||||
implementationClass = "gay.pizza.foundation.concrete.ConcreteLibraryPlugin"
|
implementationClass = "gay.pizza.foundation.concrete.ConcreteLibraryPlugin"
|
||||||
|
|
||||||
|
displayName = "Concrete Library"
|
||||||
|
description = "Gradle conventions for Foundation Bukkit plugins. Library project plugin."
|
||||||
}
|
}
|
||||||
|
|
||||||
create("concrete-plugin") {
|
create("concrete-plugin") {
|
||||||
id = "gay.pizza.foundation.concrete-plugin"
|
id = "gay.pizza.foundation.concrete-plugin"
|
||||||
implementationClass = "gay.pizza.foundation.concrete.ConcretePluginPlugin"
|
implementationClass = "gay.pizza.foundation.concrete.ConcretePluginPlugin"
|
||||||
|
|
||||||
|
displayName = "Concrete Library"
|
||||||
|
description = "Gradle conventions for Foundation Bukkit plugins. Plugin project plugin."
|
||||||
|
}
|
||||||
|
|
||||||
|
forEach { declaration ->
|
||||||
|
declaration.tags.set(listOf("foundation-concrete", "minecraft-bukkit"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val gradlePublishingKey: String? = System.getenv("GRADLE_PLUGIN_PUBLISHING_KEY")
|
||||||
|
val gradlePublishingSecret: String? = System.getenv("GRADLE_PLUGIN_PUBLISHING_SECRET")
|
||||||
|
|
||||||
|
if (gradlePublishingKey != null && gradlePublishingSecret != null) {
|
||||||
|
project.setProperty("gradle.publish.key", gradlePublishingKey.toString())
|
||||||
|
project.setProperty("gradle.publish.secret", gradlePublishingSecret.toString())
|
||||||
|
}
|
||||||
|
|
||||||
java {
|
java {
|
||||||
val version = JavaVersion.toVersion("17")
|
val version = JavaVersion.toVersion("17")
|
||||||
sourceCompatibility = version
|
sourceCompatibility = version
|
||||||
@ -99,5 +128,9 @@ publishing {
|
|||||||
}
|
}
|
||||||
|
|
||||||
tasks.withType<Wrapper> {
|
tasks.withType<Wrapper> {
|
||||||
gradleVersion = "7.6"
|
gradleVersion = "8.0"
|
||||||
|
}
|
||||||
|
|
||||||
|
java {
|
||||||
|
withSourcesJar()
|
||||||
}
|
}
|
||||||
|
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
@ -1,6 +1,6 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-bin.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-bin.zip
|
||||||
networkTimeout=10000
|
networkTimeout=10000
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
4
gradlew
vendored
4
gradlew
vendored
@ -144,7 +144,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
|||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
max*)
|
max*)
|
||||||
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
||||||
# shellcheck disable=SC3045
|
# shellcheck disable=SC3045
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
MAX_FD=$( ulimit -H -n ) ||
|
||||||
warn "Could not query maximum file descriptor limit"
|
warn "Could not query maximum file descriptor limit"
|
||||||
esac
|
esac
|
||||||
@ -152,7 +152,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
|||||||
'' | soft) :;; #(
|
'' | soft) :;; #(
|
||||||
*)
|
*)
|
||||||
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
||||||
# shellcheck disable=SC3045
|
# shellcheck disable=SC3045
|
||||||
ulimit -n "$MAX_FD" ||
|
ulimit -n "$MAX_FD" ||
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||||
esac
|
esac
|
||||||
|
@ -6,3 +6,7 @@ dependencies {
|
|||||||
implementation(project(":other-library"))
|
implementation(project(":other-library"))
|
||||||
implementation(project(":bukkit-plugins:common-library"))
|
implementation(project(":bukkit-plugins:common-library"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
concrete {
|
||||||
|
dependency(project(":bukkit-plugins:goodbye-world"))
|
||||||
|
}
|
||||||
|
BIN
samples/mixed/gradle/wrapper/gradle-wrapper.jar
vendored
BIN
samples/mixed/gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
@ -1,5 +1,6 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-all.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.1-bin.zip
|
||||||
|
networkTimeout=10000
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
12
samples/mixed/gradlew
vendored
12
samples/mixed/gradlew
vendored
@ -55,7 +55,7 @@
|
|||||||
# Darwin, MinGW, and NonStop.
|
# Darwin, MinGW, and NonStop.
|
||||||
#
|
#
|
||||||
# (3) This script is generated from the Groovy template
|
# (3) This script is generated from the Groovy template
|
||||||
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
||||||
# within the Gradle project.
|
# within the Gradle project.
|
||||||
#
|
#
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
# You can find Gradle at https://github.com/gradle/gradle/.
|
||||||
@ -80,10 +80,10 @@ do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
# This is normally unused
|
||||||
|
# shellcheck disable=SC2034
|
||||||
APP_NAME="Gradle"
|
|
||||||
APP_BASE_NAME=${0##*/}
|
APP_BASE_NAME=${0##*/}
|
||||||
|
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
||||||
|
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
@ -143,12 +143,16 @@ fi
|
|||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
max*)
|
max*)
|
||||||
|
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
MAX_FD=$( ulimit -H -n ) ||
|
||||||
warn "Could not query maximum file descriptor limit"
|
warn "Could not query maximum file descriptor limit"
|
||||||
esac
|
esac
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
'' | soft) :;; #(
|
'' | soft) :;; #(
|
||||||
*)
|
*)
|
||||||
|
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
ulimit -n "$MAX_FD" ||
|
ulimit -n "$MAX_FD" ||
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||||
esac
|
esac
|
||||||
|
1
samples/mixed/gradlew.bat
vendored
1
samples/mixed/gradlew.bat
vendored
@ -26,6 +26,7 @@ if "%OS%"=="Windows_NT" setlocal
|
|||||||
|
|
||||||
set DIRNAME=%~dp0
|
set DIRNAME=%~dp0
|
||||||
if "%DIRNAME%"=="" set DIRNAME=.
|
if "%DIRNAME%"=="" set DIRNAME=.
|
||||||
|
@rem This is normally unused
|
||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
BIN
samples/shared/gradle/wrapper/gradle-wrapper.jar
vendored
BIN
samples/shared/gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
@ -1,5 +1,6 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-all.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.1-bin.zip
|
||||||
|
networkTimeout=10000
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
12
samples/shared/gradlew
vendored
12
samples/shared/gradlew
vendored
@ -55,7 +55,7 @@
|
|||||||
# Darwin, MinGW, and NonStop.
|
# Darwin, MinGW, and NonStop.
|
||||||
#
|
#
|
||||||
# (3) This script is generated from the Groovy template
|
# (3) This script is generated from the Groovy template
|
||||||
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
||||||
# within the Gradle project.
|
# within the Gradle project.
|
||||||
#
|
#
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
# You can find Gradle at https://github.com/gradle/gradle/.
|
||||||
@ -80,10 +80,10 @@ do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
# This is normally unused
|
||||||
|
# shellcheck disable=SC2034
|
||||||
APP_NAME="Gradle"
|
|
||||||
APP_BASE_NAME=${0##*/}
|
APP_BASE_NAME=${0##*/}
|
||||||
|
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
||||||
|
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
@ -143,12 +143,16 @@ fi
|
|||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
max*)
|
max*)
|
||||||
|
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
MAX_FD=$( ulimit -H -n ) ||
|
||||||
warn "Could not query maximum file descriptor limit"
|
warn "Could not query maximum file descriptor limit"
|
||||||
esac
|
esac
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
'' | soft) :;; #(
|
'' | soft) :;; #(
|
||||||
*)
|
*)
|
||||||
|
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
ulimit -n "$MAX_FD" ||
|
ulimit -n "$MAX_FD" ||
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||||
esac
|
esac
|
||||||
|
1
samples/shared/gradlew.bat
vendored
1
samples/shared/gradlew.bat
vendored
@ -26,6 +26,7 @@ if "%OS%"=="Windows_NT" setlocal
|
|||||||
|
|
||||||
set DIRNAME=%~dp0
|
set DIRNAME=%~dp0
|
||||||
if "%DIRNAME%"=="" set DIRNAME=.
|
if "%DIRNAME%"=="" set DIRNAME=.
|
||||||
|
@rem This is normally unused
|
||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
BIN
samples/simple/gradle/wrapper/gradle-wrapper.jar
vendored
BIN
samples/simple/gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
@ -1,5 +1,6 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-all.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.1-bin.zip
|
||||||
|
networkTimeout=10000
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
12
samples/simple/gradlew
vendored
12
samples/simple/gradlew
vendored
@ -55,7 +55,7 @@
|
|||||||
# Darwin, MinGW, and NonStop.
|
# Darwin, MinGW, and NonStop.
|
||||||
#
|
#
|
||||||
# (3) This script is generated from the Groovy template
|
# (3) This script is generated from the Groovy template
|
||||||
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
||||||
# within the Gradle project.
|
# within the Gradle project.
|
||||||
#
|
#
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
# You can find Gradle at https://github.com/gradle/gradle/.
|
||||||
@ -80,10 +80,10 @@ do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
# This is normally unused
|
||||||
|
# shellcheck disable=SC2034
|
||||||
APP_NAME="Gradle"
|
|
||||||
APP_BASE_NAME=${0##*/}
|
APP_BASE_NAME=${0##*/}
|
||||||
|
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
||||||
|
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
@ -143,12 +143,16 @@ fi
|
|||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
max*)
|
max*)
|
||||||
|
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
MAX_FD=$( ulimit -H -n ) ||
|
||||||
warn "Could not query maximum file descriptor limit"
|
warn "Could not query maximum file descriptor limit"
|
||||||
esac
|
esac
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
'' | soft) :;; #(
|
'' | soft) :;; #(
|
||||||
*)
|
*)
|
||||||
|
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
||||||
|
# shellcheck disable=SC3045
|
||||||
ulimit -n "$MAX_FD" ||
|
ulimit -n "$MAX_FD" ||
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||||
esac
|
esac
|
||||||
|
1
samples/simple/gradlew.bat
vendored
1
samples/simple/gradlew.bat
vendored
@ -26,6 +26,7 @@ if "%OS%"=="Windows_NT" setlocal
|
|||||||
|
|
||||||
set DIRNAME=%~dp0
|
set DIRNAME=%~dp0
|
||||||
if "%DIRNAME%"=="" set DIRNAME=.
|
if "%DIRNAME%"=="" set DIRNAME=.
|
||||||
|
@rem This is normally unused
|
||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
@ -12,6 +12,8 @@ open class ConcreteBasePlugin : Plugin<Project> {
|
|||||||
override fun apply(project: Project) {
|
override fun apply(project: Project) {
|
||||||
val versionWithBuild = if (System.getenv("CI_PIPELINE_IID") != null) {
|
val versionWithBuild = if (System.getenv("CI_PIPELINE_IID") != null) {
|
||||||
project.rootProject.version.toString() + ".${System.getenv("CI_PIPELINE_IID")}"
|
project.rootProject.version.toString() + ".${System.getenv("CI_PIPELINE_IID")}"
|
||||||
|
} else if (System.getenv("CONCRETE_BUILD_NUMBER") != null) {
|
||||||
|
project.rootProject.version.toString() + ".${System.getenv("CONCRETE_BUILD_NUMBER")}"
|
||||||
} else {
|
} else {
|
||||||
"DEV"
|
"DEV"
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,12 @@
|
|||||||
|
package gay.pizza.foundation.concrete
|
||||||
|
|
||||||
|
import org.gradle.api.DomainObjectSet
|
||||||
|
import org.gradle.api.Project
|
||||||
|
|
||||||
|
interface ConcretePluginExtension {
|
||||||
|
val dependencies: DomainObjectSet<Project>
|
||||||
|
|
||||||
|
fun dependency(project: Project) {
|
||||||
|
dependencies.add(project)
|
||||||
|
}
|
||||||
|
}
|
@ -9,14 +9,20 @@ class ConcretePluginPlugin : ConcreteBaseBukkitPlugin() {
|
|||||||
override fun apply(project: Project) {
|
override fun apply(project: Project) {
|
||||||
super.apply(project)
|
super.apply(project)
|
||||||
|
|
||||||
|
project.extensions.create("concrete", ConcretePluginExtension::class.java)
|
||||||
|
|
||||||
project.plugins.apply("com.github.johnrengelman.shadow")
|
project.plugins.apply("com.github.johnrengelman.shadow")
|
||||||
|
|
||||||
project.tasks.find<ProcessResources>("processResources")!!.apply {
|
// During IDEA project import, if this code is active, it will print warnings.
|
||||||
val props = mapOf("version" to project.version.toString())
|
// This will make the VERSION field unexpanded if you run using the IntelliJ build system.
|
||||||
inputs.properties(props)
|
if (!project.properties.containsKey("idea.gradle.do.not.build.tasks")) {
|
||||||
filteringCharset = "UTF-8"
|
project.tasks.find<ProcessResources>("processResources")!!.apply {
|
||||||
filesMatching("plugin.yml") {
|
val props = mapOf("version" to project.version.toString())
|
||||||
expand(props)
|
inputs.properties(props)
|
||||||
|
filteringCharset = "UTF-8"
|
||||||
|
filesMatching("plugin.yml") {
|
||||||
|
expand(props)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@ package gay.pizza.foundation.concrete
|
|||||||
|
|
||||||
import org.gradle.api.provider.Property
|
import org.gradle.api.provider.Property
|
||||||
|
|
||||||
interface ConcreteExtension {
|
interface ConcreteRootExtension {
|
||||||
val paperServerVersionGroup: Property<String>
|
val paperServerVersionGroup: Property<String>
|
||||||
val paperApiVersion: Property<String>
|
val paperApiVersion: Property<String>
|
||||||
val minecraftServerPath: Property<String>
|
val minecraftServerPath: Property<String>
|
@ -9,7 +9,7 @@ import java.nio.file.Paths
|
|||||||
class ConcreteRootPlugin : Plugin<Project> {
|
class ConcreteRootPlugin : Plugin<Project> {
|
||||||
override fun apply(project: Project) {
|
override fun apply(project: Project) {
|
||||||
project.apply(plugin = "base")
|
project.apply(plugin = "base")
|
||||||
project.extensions.create<ConcreteExtension>("concrete")
|
project.extensions.create<ConcreteRootExtension>("concrete")
|
||||||
val setupPaperServer = project.tasks.create<SetupPaperServer>("setupPaperServer")
|
val setupPaperServer = project.tasks.create<SetupPaperServer>("setupPaperServer")
|
||||||
val runPaperServer = project.tasks.create<RunPaperServer>("runPaperServer")
|
val runPaperServer = project.tasks.create<RunPaperServer>("runPaperServer")
|
||||||
runPaperServer.dependsOn(setupPaperServer)
|
runPaperServer.dependsOn(setupPaperServer)
|
||||||
|
@ -0,0 +1,55 @@
|
|||||||
|
package gay.pizza.foundation.concrete
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The extensible update manifest format.
|
||||||
|
*/
|
||||||
|
data class ExtensibleManifest(
|
||||||
|
/**
|
||||||
|
* The items the manifest describes.
|
||||||
|
*/
|
||||||
|
val items: List<ExtensibleManifestItem>
|
||||||
|
)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An item in the update manifest.
|
||||||
|
*/
|
||||||
|
data class ExtensibleManifestItem(
|
||||||
|
/**
|
||||||
|
* The name of the item.
|
||||||
|
*/
|
||||||
|
val name: String,
|
||||||
|
/**
|
||||||
|
* The type of item, for example "bukkit-plugin"
|
||||||
|
*/
|
||||||
|
val type: String,
|
||||||
|
/**
|
||||||
|
* The version of the item.
|
||||||
|
*/
|
||||||
|
val version: String,
|
||||||
|
/**
|
||||||
|
* The dependencies of the item.
|
||||||
|
*/
|
||||||
|
val dependencies: List<String>,
|
||||||
|
/**
|
||||||
|
* The files that are required to install the item.
|
||||||
|
*/
|
||||||
|
val files: List<String>
|
||||||
|
)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A file built from the item.
|
||||||
|
*/
|
||||||
|
data class ExtensibleManifestItemFile(
|
||||||
|
/**
|
||||||
|
* The name of the file.
|
||||||
|
*/
|
||||||
|
val name: String,
|
||||||
|
/**
|
||||||
|
* A type of file. For example: "plugin-jar".
|
||||||
|
*/
|
||||||
|
val type: String,
|
||||||
|
/**
|
||||||
|
* The relative path to download the file.
|
||||||
|
*/
|
||||||
|
val path: String
|
||||||
|
)
|
@ -1,7 +1,9 @@
|
|||||||
package gay.pizza.foundation.concrete
|
package gay.pizza.foundation.concrete
|
||||||
|
|
||||||
import com.google.gson.Gson
|
import com.google.gson.Gson
|
||||||
|
import com.google.gson.GsonBuilder
|
||||||
|
|
||||||
object Globals {
|
object Globals {
|
||||||
val gson = Gson()
|
val gsonPretty: Gson = GsonBuilder().setPrettyPrinting().create()
|
||||||
|
val gson: Gson = Gson()
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ open class RunPaperServer : RunMinecraftServer() {
|
|||||||
|
|
||||||
@Internal
|
@Internal
|
||||||
override fun getServerDirectory(): File {
|
override fun getServerDirectory(): File {
|
||||||
val concrete = project.extensions.getByType<ConcreteExtension>()
|
val concrete = project.extensions.getByType<ConcreteRootExtension>()
|
||||||
return project.file(concrete.minecraftServerPath.get())
|
return project.file(concrete.minecraftServerPath.get())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ abstract class SetupMinecraftServer : DefaultTask() {
|
|||||||
Files.createSymbolicLink(pluginLinkFile.toPath(), pluginJarFile.toPath())
|
Files.createSymbolicLink(pluginLinkFile.toPath(), pluginJarFile.toPath())
|
||||||
}
|
}
|
||||||
|
|
||||||
val concrete = project.extensions.getByType<ConcreteExtension>()
|
val concrete = project.extensions.getByType<ConcreteRootExtension>()
|
||||||
if (concrete.acceptServerEula.isPresent && concrete.acceptServerEula.get()) {
|
if (concrete.acceptServerEula.isPresent && concrete.acceptServerEula.get()) {
|
||||||
val writer = minecraftServerDirectory.resolve("eula.txt").bufferedWriter()
|
val writer = minecraftServerDirectory.resolve("eula.txt").bufferedWriter()
|
||||||
val properties = Properties()
|
val properties = Properties()
|
||||||
|
@ -18,7 +18,7 @@ open class SetupPaperServer : SetupMinecraftServer() {
|
|||||||
|
|
||||||
@TaskAction
|
@TaskAction
|
||||||
fun setupPaperServer() {
|
fun setupPaperServer() {
|
||||||
val concrete = project.extensions.getByType<ConcreteExtension>()
|
val concrete = project.extensions.getByType<ConcreteRootExtension>()
|
||||||
val minecraftServerDirectory = getServerDirectory()
|
val minecraftServerDirectory = getServerDirectory()
|
||||||
val paperJarFile = project.file("${minecraftServerDirectory}/paper.jar")
|
val paperJarFile = project.file("${minecraftServerDirectory}/paper.jar")
|
||||||
if (!paperJarFile.exists() || shouldUpdatePaperServer) {
|
if (!paperJarFile.exists() || shouldUpdatePaperServer) {
|
||||||
@ -50,7 +50,7 @@ open class SetupPaperServer : SetupMinecraftServer() {
|
|||||||
|
|
||||||
@Internal
|
@Internal
|
||||||
override fun getServerDirectory(): File {
|
override fun getServerDirectory(): File {
|
||||||
val concrete = project.extensions.getByType<ConcreteExtension>()
|
val concrete = project.extensions.getByType<ConcreteRootExtension>()
|
||||||
return project.file(concrete.minecraftServerPath.get())
|
return project.file(concrete.minecraftServerPath.get())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,10 +9,10 @@ open class UpdateManifestTask : DefaultTask() {
|
|||||||
@TaskAction
|
@TaskAction
|
||||||
fun update() {
|
fun update() {
|
||||||
val manifestsDir = ensureManifestsDirectory()
|
val manifestsDir = ensureManifestsDirectory()
|
||||||
val updateFile = manifestsDir.resolve("update.json")
|
val rootPath = project.projectDir.toPath()
|
||||||
val rootPath = project.rootProject.rootDir.toPath()
|
val legacyUpdateManifest = project.findPluginProjects().mapNotNull { project ->
|
||||||
val updateManifest = project.findPluginProjects().mapNotNull { project ->
|
|
||||||
val paths = project.shadowJarOutputs!!.allFilesRelativeToPath(rootPath)
|
val paths = project.shadowJarOutputs!!.allFilesRelativeToPath(rootPath)
|
||||||
|
|
||||||
if (paths.isNotEmpty()) {
|
if (paths.isNotEmpty()) {
|
||||||
project.name to mapOf(
|
project.name to mapOf(
|
||||||
"version" to project.version,
|
"version" to project.version,
|
||||||
@ -21,7 +21,29 @@ open class UpdateManifestTask : DefaultTask() {
|
|||||||
} else null
|
} else null
|
||||||
}.toMap()
|
}.toMap()
|
||||||
|
|
||||||
Files.writeString(updateFile, Globals.gson.toJson(updateManifest))
|
val legacyUpdateFile = manifestsDir.resolve("update.json")
|
||||||
|
Files.writeString(legacyUpdateFile, Globals.gson.toJson(legacyUpdateManifest))
|
||||||
|
|
||||||
|
val extensibleUpdateManifestItems = project.findPluginProjects().mapNotNull { project ->
|
||||||
|
val paths = project.shadowJarOutputs!!.allFilesRelativeToPath(rootPath)
|
||||||
|
|
||||||
|
val dependencies = project.concretePluginExtension.dependencies.map { it.name }
|
||||||
|
ExtensibleManifestItem(
|
||||||
|
name = project.name,
|
||||||
|
type = "bukkit-plugin",
|
||||||
|
version = project.version.toString(),
|
||||||
|
dependencies = dependencies,
|
||||||
|
files = paths.map { it.toUnixString() }
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
val extensibleUpdateManifest = ExtensibleManifest(
|
||||||
|
items = extensibleUpdateManifestItems
|
||||||
|
)
|
||||||
|
|
||||||
|
val extensibleUpdateManifestFile = manifestsDir.resolve("manifest.json")
|
||||||
|
Files.writeString(
|
||||||
|
extensibleUpdateManifestFile, Globals.gsonPretty.toJson(extensibleUpdateManifest) + "\n")
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun ensureManifestsDirectory(): Path {
|
private fun ensureManifestsDirectory(): Path {
|
||||||
|
@ -30,20 +30,23 @@ internal val Project.shadowJarTask: ShadowJar?
|
|||||||
internal val Project.shadowJarOutputs: TaskOutputs?
|
internal val Project.shadowJarOutputs: TaskOutputs?
|
||||||
get() = shadowJarTask?.outputs
|
get() = shadowJarTask?.outputs
|
||||||
|
|
||||||
internal val Project.concreteRootExtension: ConcreteExtension
|
internal val Project.concreteRootExtension: ConcreteRootExtension
|
||||||
get() = findTargetParent(
|
get() = findTargetParent(
|
||||||
valid = { extensions.findByType(ConcreteExtension::class.java) != null },
|
valid = { extensions.findByType(ConcreteRootExtension::class.java) != null },
|
||||||
extract = { extensions.findByType(ConcreteExtension::class.java)!! },
|
extract = { extensions.findByType(ConcreteRootExtension::class.java)!! },
|
||||||
error = { "Failed to find concrete root. Did you apply the concrete root plugin?" }
|
error = { "Failed to find concrete root. Did you apply the concrete root plugin?" }
|
||||||
)
|
)
|
||||||
|
|
||||||
|
internal val Project.concretePluginExtension: ConcretePluginExtension
|
||||||
|
get() = extensions.getByType(ConcretePluginExtension::class.java)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Finds the concrete root project, which is the first project in the project hierarchy
|
* Finds the concrete root project, which is the first project in the project hierarchy
|
||||||
* that has the concrete extension.
|
* that has the concrete extension.
|
||||||
*/
|
*/
|
||||||
internal val Project.concreteRootProject: Project
|
internal val Project.concreteRootProject: Project
|
||||||
get() = findTargetParent(
|
get() = findTargetParent(
|
||||||
valid = { extensions.findByType(ConcreteExtension::class.java) != null },
|
valid = { extensions.findByType(ConcreteRootExtension::class.java) != null },
|
||||||
extract = { this },
|
extract = { this },
|
||||||
error = { "Failed to find concrete root. Did you apply the concrete root plugin?" }
|
error = { "Failed to find concrete root. Did you apply the concrete root plugin?" }
|
||||||
)
|
)
|
||||||
|
10
tools/ensure-new-lines.sh
Executable file
10
tools/ensure-new-lines.sh
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
git ls-files -z | while IFS= read -rd '' f
|
||||||
|
do
|
||||||
|
if file --mime-encoding "$f" | grep -qv binary
|
||||||
|
then
|
||||||
|
tail -c1 < "$f" | read -r _ || echo >> "$f"
|
||||||
|
fi
|
||||||
|
done
|
Reference in New Issue
Block a user