This commit is contained in:
parent
2f140c4a60
commit
1d4494d905
@ -1,5 +1,8 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
**1.1.9**
|
||||||
|
* Add ```modupdater``` Entry-Point
|
||||||
|
|
||||||
**1.1.8**
|
**1.1.8**
|
||||||
* Strict Minecraft Version Checking by Default
|
* Strict Minecraft Version Checking by Default
|
||||||
* Print Message To Log Showing All Scanned Mods
|
* Print Message To Log Showing All Scanned Mods
|
||||||
|
2
Jenkinsfile
vendored
2
Jenkinsfile
vendored
@ -7,7 +7,7 @@ pipeline {
|
|||||||
stages {
|
stages {
|
||||||
stage('Build') {
|
stage('Build') {
|
||||||
steps {
|
steps {
|
||||||
sh './gradlew build'
|
sh './gradlew build publish'
|
||||||
}
|
}
|
||||||
post {
|
post {
|
||||||
success {
|
success {
|
||||||
|
@ -124,4 +124,16 @@ In strict mode it only marks a file as compatibleif the Minecraft version is ide
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
In loose mode, it will also mark a file as compatible if it has the same release target.
|
In loose mode, it will also mark a file as compatible if it has the same release target.
|
||||||
|
|
||||||
|
## Custom Version Compatibility Checking
|
||||||
|
You can also specify the ```modupdater``` entry-point as a ```ModUpdaterEntryPoint``` to check if a version is compatible with the current MC version.
|
||||||
|
```gradle
|
||||||
|
repositories {
|
||||||
|
maven { url 'https://maven.thebrokenrail.com' }
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
modCompileOnly 'com.thebrokenrail:modupdater:VERSION'
|
||||||
|
// VERSION = "<Mod Version>+<MC Version>", for example "1.2.4+20w12a"
|
||||||
|
}
|
||||||
|
```
|
16
build.gradle
16
build.gradle
@ -1,6 +1,7 @@
|
|||||||
plugins {
|
plugins {
|
||||||
id 'fabric-loom' version '0.4-SNAPSHOT'
|
id 'fabric-loom' version '0.4-SNAPSHOT'
|
||||||
id 'com.matthewprenger.cursegradle' version '1.4.0'
|
id 'com.matthewprenger.cursegradle' version '1.4.0'
|
||||||
|
id 'maven-publish'
|
||||||
}
|
}
|
||||||
|
|
||||||
compileJava {
|
compileJava {
|
||||||
@ -99,4 +100,19 @@ if (project.hasProperty('curseforge.api_key')) {
|
|||||||
forgeGradleIntegration = false
|
forgeGradleIntegration = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
publishing {
|
||||||
|
publications {
|
||||||
|
mavenJava(MavenPublication) {
|
||||||
|
artifact(remapJar) {
|
||||||
|
builtBy remapJar
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
repositories {
|
||||||
|
maven {
|
||||||
|
url '/data/maven'
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -9,7 +9,7 @@ org.gradle.jvmargs = -Xmx1G
|
|||||||
fabric_loader_version = 0.8.8+build.202
|
fabric_loader_version = 0.8.8+build.202
|
||||||
|
|
||||||
# Mod Properties
|
# Mod Properties
|
||||||
mod_version = 1.1.8
|
mod_version = 1.1.9
|
||||||
maven_group = com.thebrokenrail
|
maven_group = com.thebrokenrail
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
|
@ -6,7 +6,7 @@ import javax.annotation.Nullable;
|
|||||||
|
|
||||||
public interface UpdateStrategy {
|
public interface UpdateStrategy {
|
||||||
@Nullable
|
@Nullable
|
||||||
ModUpdate run(ConfigObject obj, String oldVersion, String name);
|
ModUpdate run(ConfigObject obj, String oldVersion, String name, String id);
|
||||||
|
|
||||||
default boolean isStrict(ConfigObject obj) {
|
default boolean isStrict(ConfigObject obj) {
|
||||||
try {
|
try {
|
||||||
|
@ -0,0 +1,5 @@
|
|||||||
|
package com.thebrokenrail.modupdater.api.entrypoint;
|
||||||
|
|
||||||
|
public interface ModUpdaterEntryPoint {
|
||||||
|
boolean isVersionCompatible(String version);
|
||||||
|
}
|
@ -33,7 +33,7 @@ public class CurseForgeStrategy implements UpdateStrategy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public ModUpdate run(ConfigObject obj, String oldVersion, String name) {
|
public ModUpdate run(ConfigObject obj, String oldVersion, String name, String id) {
|
||||||
int projectID;
|
int projectID;
|
||||||
try {
|
try {
|
||||||
projectID = obj.getInt("projectID");
|
projectID = obj.getInt("projectID");
|
||||||
@ -76,7 +76,7 @@ public class CurseForgeStrategy implements UpdateStrategy {
|
|||||||
for (CurseForgeFile file : files) {
|
for (CurseForgeFile file : files) {
|
||||||
if (Util.isFileCompatible(file.fileName)) {
|
if (Util.isFileCompatible(file.fileName)) {
|
||||||
String fileVersion = Util.getVersionFromFileName(file.fileName);
|
String fileVersion = Util.getVersionFromFileName(file.fileName);
|
||||||
if ((Arrays.asList(file.gameVersion).contains(versionStr) && strict) || Util.isVersionCompatible(fileVersion, strict)) {
|
if ((Arrays.asList(file.gameVersion).contains(versionStr) && !strict) || Util.isVersionCompatible(id, fileVersion, strict)) {
|
||||||
if (newestFile != null) {
|
if (newestFile != null) {
|
||||||
String newestFileVersion = Util.getVersionFromFileName(newestFile.fileName);
|
String newestFileVersion = Util.getVersionFromFileName(newestFile.fileName);
|
||||||
try {
|
try {
|
||||||
|
@ -35,7 +35,7 @@ public class GitHubReleasesStrategy implements UpdateStrategy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public ModUpdate run(ConfigObject obj, String oldVersion, String name) {
|
public ModUpdate run(ConfigObject obj, String oldVersion, String name, String id) {
|
||||||
String owner;
|
String owner;
|
||||||
String repo;
|
String repo;
|
||||||
try {
|
try {
|
||||||
@ -73,7 +73,7 @@ public class GitHubReleasesStrategy implements UpdateStrategy {
|
|||||||
for (GitHubReleaseAsset asset : release.assets) {
|
for (GitHubReleaseAsset asset : release.assets) {
|
||||||
if (Util.isFileCompatible(asset.name)) {
|
if (Util.isFileCompatible(asset.name)) {
|
||||||
String fileVersion = Util.getVersionFromFileName(asset.name);
|
String fileVersion = Util.getVersionFromFileName(asset.name);
|
||||||
if (Util.isVersionCompatible(fileVersion, strict)) {
|
if (Util.isVersionCompatible(id, fileVersion, strict)) {
|
||||||
if (newestFile != null) {
|
if (newestFile != null) {
|
||||||
try {
|
try {
|
||||||
if (SemanticVersion.parse(fileVersion).compareTo(SemanticVersion.parse(fileVersion)) > 0) {
|
if (SemanticVersion.parse(fileVersion).compareTo(SemanticVersion.parse(fileVersion)) > 0) {
|
||||||
|
@ -32,7 +32,7 @@ public class JSONStrategy implements UpdateStrategy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public ModUpdate run(ConfigObject obj, String oldVersion, String name) {
|
public ModUpdate run(ConfigObject obj, String oldVersion, String name, String id) {
|
||||||
String url;
|
String url;
|
||||||
try {
|
try {
|
||||||
url = obj.getString("url");
|
url = obj.getString("url");
|
||||||
|
@ -40,7 +40,7 @@ public class MavenStrategy implements UpdateStrategy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public ModUpdate run(ConfigObject obj, String oldVersion, String name) {
|
public ModUpdate run(ConfigObject obj, String oldVersion, String name, String id) {
|
||||||
String repository;
|
String repository;
|
||||||
String group;
|
String group;
|
||||||
String artifact;
|
String artifact;
|
||||||
@ -87,7 +87,7 @@ public class MavenStrategy implements UpdateStrategy {
|
|||||||
Node node = versions.item(i);
|
Node node = versions.item(i);
|
||||||
|
|
||||||
String version = node.getTextContent();
|
String version = node.getTextContent();
|
||||||
if (Util.isVersionCompatible(version, strict)) {
|
if (Util.isVersionCompatible(id, version, strict)) {
|
||||||
if (newestVersion != null) {
|
if (newestVersion != null) {
|
||||||
try {
|
try {
|
||||||
if (SemanticVersion.parse(version).compareTo(SemanticVersion.parse(newestVersion)) > 0) {
|
if (SemanticVersion.parse(version).compareTo(SemanticVersion.parse(newestVersion)) > 0) {
|
||||||
|
@ -54,7 +54,7 @@ public class UpdateStrategyRunner {
|
|||||||
|
|
||||||
scan.accept(name);
|
scan.accept(name);
|
||||||
|
|
||||||
return strategyObj.run(obj, oldVersion, name);
|
return strategyObj.run(obj, oldVersion, name, metadata.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ModUpdate[] checkAllModsForUpdates() {
|
public static ModUpdate[] checkAllModsForUpdates() {
|
||||||
|
@ -1,10 +1,13 @@
|
|||||||
package com.thebrokenrail.modupdater.util;
|
package com.thebrokenrail.modupdater.util;
|
||||||
|
|
||||||
import com.mojang.bridge.game.GameVersion;
|
import com.mojang.bridge.game.GameVersion;
|
||||||
|
import com.thebrokenrail.modupdater.ModUpdater;
|
||||||
import com.thebrokenrail.modupdater.api.ConfigObject;
|
import com.thebrokenrail.modupdater.api.ConfigObject;
|
||||||
|
import com.thebrokenrail.modupdater.api.entrypoint.ModUpdaterEntryPoint;
|
||||||
import com.thebrokenrail.modupdater.api.impl.ConfigObjectHardcoded;
|
import com.thebrokenrail.modupdater.api.impl.ConfigObjectHardcoded;
|
||||||
import net.fabricmc.loader.api.FabricLoader;
|
import net.fabricmc.loader.api.FabricLoader;
|
||||||
import net.fabricmc.loader.api.ModContainer;
|
import net.fabricmc.loader.api.ModContainer;
|
||||||
|
import net.fabricmc.loader.api.entrypoint.EntrypointContainer;
|
||||||
import net.minecraft.MinecraftVersion;
|
import net.minecraft.MinecraftVersion;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
@ -12,6 +15,7 @@ import java.io.IOException;
|
|||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
@ -80,7 +84,14 @@ public class Util {
|
|||||||
return versionStr.endsWith(prefix + minecraftVersionSemantic) || versionStr.endsWith(prefix + minecraftVersion.getName()) || (!strict && (versionStr.endsWith(prefix + minecraftVersion.getReleaseTarget()) || versionStr.endsWith(prefix + getMajorVersion())));
|
return versionStr.endsWith(prefix + minecraftVersionSemantic) || versionStr.endsWith(prefix + minecraftVersion.getName()) || (!strict && (versionStr.endsWith(prefix + minecraftVersion.getReleaseTarget()) || versionStr.endsWith(prefix + getMajorVersion())));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isVersionCompatible(String versionStr, boolean strict) {
|
public static boolean isVersionCompatible(String id, String versionStr, boolean strict) {
|
||||||
|
List<EntrypointContainer<ModUpdaterEntryPoint>> list = FabricLoader.getInstance().getEntrypointContainers(ModUpdater.NAMESPACE, ModUpdaterEntryPoint.class);
|
||||||
|
for (EntrypointContainer<ModUpdaterEntryPoint> container : list) {
|
||||||
|
if (container.getProvider().getMetadata().getId().equals(id)) {
|
||||||
|
return container.getEntrypoint().isVersionCompatible(versionStr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return isVersionCompatible(versionStr, '+', strict) || isVersionCompatible(versionStr, '-', strict);
|
return isVersionCompatible(versionStr, '+', strict) || isVersionCompatible(versionStr, '-', strict);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user