Skip to content

Commit

Permalink
Merge pull request #8 from okocraft/refactoring
Browse files Browse the repository at this point in the history
Refactoring
  • Loading branch information
Siroshun09 authored Apr 28, 2024
2 parents 3d9692e + 6a568bb commit d450ba9
Show file tree
Hide file tree
Showing 16 changed files with 448 additions and 581 deletions.
10 changes: 10 additions & 0 deletions .github/workflows/gradle.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
name: Build
on: [ push, pull_request ]

jobs:
build:
uses: okocraft/workflows/.github/workflows/gradle.yml@v1
with:
java-version: '21'
package-name: BoxTradeStick-Build-${{ github.run_number }}
upload-test-results: true
25 changes: 10 additions & 15 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,29 +1,29 @@
plugins {
java
id("io.papermc.paperweight.userdev") version "1.6.0"
id("io.github.goooler.shadow") version "8.1.7"
}

group = "net.okocraft.boxtradestick"
version = "1.6-SNAPSHOT"

val mcVersion = "1.20.5"
val fullVersion = "${version}-mc${mcVersion}"

repositories {
mavenCentral()
maven(url = "https://repo.papermc.io/repository/maven-public/")
maven(url = "https://okocraft.github.io/Box/maven-snapshot/")
}

dependencies {
paperweight.paperDevBundle("1.20.5-R0.1-SNAPSHOT")

implementation("com.github.siroshun09.configapi:configapi-yaml:4.6.4")
implementation("com.github.siroshun09.translationloader:translationloader:2.0.2")
paperweight.paperDevBundle("$mcVersion-R0.1-SNAPSHOT")

compileOnly("net.okocraft.box:box-api:6.0.0-SNAPSHOT")
compileOnly("net.okocraft.box:box-gui-feature:6.0.0-SNAPSHOT")
compileOnly("net.okocraft.box:box-stick-feature:6.0.0-SNAPSHOT")

testImplementation("org.junit.jupiter:junit-jupiter-api:5.10.2")
testRuntimeOnly("io.papermc.paper:paper-api:1.20.5-R0.1-SNAPSHOT")
testRuntimeOnly("io.papermc.paper:paper-api:$mcVersion-R0.1-SNAPSHOT")
testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine")
testRuntimeOnly("org.junit.platform:junit-platform-launcher")
}
Expand All @@ -41,22 +41,17 @@ tasks {
options.release.set(21)
}

build {
dependsOn(shadowJar)
}

processResources {
filesMatching(listOf("plugin.yml", "en.yml", "ja_JP.yml")) {
expand("projectVersion" to version)
filesMatching(listOf("paper-plugin.yml")) {
expand("projectVersion" to version, "apiVersion" to mcVersion)
}
}

test {
useJUnitPlatform()
}

shadowJar {
minimize()
relocate("com.github.siroshun09", "net.okocraft.boxtradestick.lib")
jar {
archiveFileName = "BoxTradeStick-$fullVersion.jar"
}
}
119 changes: 54 additions & 65 deletions src/main/java/net/okocraft/boxtradestick/BoxTradeStickPlugin.java
Original file line number Diff line number Diff line change
@@ -1,90 +1,79 @@
package net.okocraft.boxtradestick;

import java.io.IOException;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.Locale;
import java.util.jar.JarFile;
import java.util.logging.Level;
import net.kyori.adventure.key.Key;
import com.github.siroshun09.configapi.api.Configuration;
import com.github.siroshun09.configapi.api.util.ResourceUtils;
import com.github.siroshun09.configapi.yaml.YamlConfiguration;
import com.github.siroshun09.translationloader.ConfigurationLoader;
import com.github.siroshun09.translationloader.TranslationLoader;
import com.github.siroshun09.translationloader.directory.TranslationDirectory;
import com.github.siroshun09.messages.api.directory.DirectorySource;
import com.github.siroshun09.messages.api.directory.MessageProcessors;
import com.github.siroshun09.messages.api.source.StringMessageMap;
import com.github.siroshun09.messages.api.util.PropertiesFile;
import com.github.siroshun09.messages.minimessage.localization.MiniMessageLocalization;
import com.github.siroshun09.messages.minimessage.source.MiniMessageSource;
import net.okocraft.box.api.BoxAPI;
import net.okocraft.box.feature.stick.StickFeature;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

public final class BoxTradeStickPlugin extends JavaPlugin {

private final Path jarFile;

private final TranslationDirectory translationDirectory;

public BoxTradeStickPlugin() {
this.jarFile = Paths.get(getClass().getProtectionDomain().getCodeSource().getLocation().getPath());

Path pluginDirectory = getDataFolder().toPath();

this.translationDirectory =
TranslationDirectory.newBuilder()
.setDirectory(pluginDirectory.resolve("languages"))
.setKey(Key.key("boxtradestick", "languages"))
.setDefaultLocale(Locale.ENGLISH)
.onDirectoryCreated(this::saveDefaultLanguages)
.setVersion(getPluginMeta().getVersion()) // getPluginMeta never returns null
.setTranslationLoaderCreator(this::getBundledTranslation)
.build();
}

private void saveDefaultLanguages(@NotNull Path directory) throws IOException {
var english = "en.yml";
ResourceUtils.copyFromJarIfNotExists(jarFile, english, directory.resolve(english));

var japanese = "ja_JP.yml";
ResourceUtils.copyFromJarIfNotExists(jarFile, japanese, directory.resolve(japanese));
}

private @Nullable TranslationLoader getBundledTranslation(@NotNull Locale locale) throws IOException {
var strLocale = locale.toString();

if (!(strLocale.equals("en") || strLocale.equals("ja_JP"))) {
return null;
}

Configuration source;

try (var jar = new JarFile(getFile());
var input = ResourceUtils.getInputStreamFromJar(jar, strLocale + ".yml")) {
source = YamlConfiguration.loadFromInputStream(input);
}
import java.io.IOException;
import java.util.Locale;
import java.util.Map;

var loader = ConfigurationLoader.create(locale, source);
loader.load();
public final class BoxTradeStickPlugin extends JavaPlugin {

return loader;
}
private MiniMessageLocalization localization;

@Override
public void onLoad() {

try {
translationDirectory.load();
this.loadMessages();
} catch (IOException e) {
getLogger().log(Level.SEVERE, "Could not load languages", e);
this.getSLF4JLogger().error("Could not load languages.", e);
}
}

@Override
public void onEnable() {
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
if (!BoxAPI.isLoaded()) {
this.getSLF4JLogger().error("Box is not loaded. All features of BoxTradeStick will not be working.");
return;
}

BoxAPI.api().getFeatureProvider().getFeature(StickFeature.class)
.map(StickFeature::getBoxStickItem)
.map(stick -> new PlayerListener(stick, this.localization))
.ifPresentOrElse(
listener -> this.getServer().getPluginManager().registerEvents(listener, this),
() -> this.getSLF4JLogger().error("Failed to get the Box Stick from Box.")
);
}

@Override
public void onDisable() {
translationDirectory.unload();
this.getServer().getOnlinePlayers().forEach(player -> {
if (MerchantRecipesGUI.fromInventory(player.getOpenInventory().getTopInventory()) != null) {
player.closeInventory();
}
});
}

private void loadMessages() throws IOException {
if (this.localization == null) { // on startup
this.localization = new MiniMessageLocalization(MiniMessageSource.create(StringMessageMap.create(Languages.defaultMessages())), Languages::getLocaleFrom);
} else { // on reload
this.localization.clearSources();
}

DirectorySource.propertiesFiles(this.getDataFolder().toPath().resolve("languages"))
.defaultLocale(Locale.ENGLISH, Locale.JAPANESE)
.messageProcessor(MessageProcessors.appendMissingMessagesToPropertiesFile(this::loadDefaultMessageMap))
.load(loaded -> this.localization.addSource(loaded.locale(), MiniMessageSource.create(loaded.messageSource())));
}

private @Nullable Map<String, String> loadDefaultMessageMap(@NotNull Locale locale) throws IOException {
if (locale.equals(Locale.ENGLISH)) {
return Languages.defaultMessages();
} else {
try (var input = this.getResource(locale + ".properties")) {
return input != null ? PropertiesFile.load(input) : null;
}
}
}
}
116 changes: 0 additions & 116 deletions src/main/java/net/okocraft/boxtradestick/BoxUtil.java

This file was deleted.

Loading

0 comments on commit d450ba9

Please sign in to comment.