mirror of
https://github.com/GeyserMC/Geyser.git
synced 2024-08-14 23:57:35 +00:00
Merge branch 'feature/extensions' into api-version-check
This commit is contained in:
commit
29c9bde9ef
1 changed files with 4 additions and 4 deletions
|
@ -49,12 +49,12 @@ import java.util.stream.Stream;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class GeyserExtensionLoader extends ExtensionLoader {
|
public class GeyserExtensionLoader extends ExtensionLoader {
|
||||||
private static final Path EXTENSION_DIRECTORY = Paths.get("extensions");
|
|
||||||
private static final Pattern[] EXTENSION_FILTERS = new Pattern[] { Pattern.compile("^.+\\.jar$") };
|
private static final Pattern[] EXTENSION_FILTERS = new Pattern[] { Pattern.compile("^.+\\.jar$") };
|
||||||
|
|
||||||
private final Object2ReferenceMap<String, Class<?>> classes = new Object2ReferenceOpenHashMap<>();
|
private final Object2ReferenceMap<String, Class<?>> classes = new Object2ReferenceOpenHashMap<>();
|
||||||
private final Map<String, GeyserExtensionClassLoader> classLoaders = new HashMap<>();
|
private final Map<String, GeyserExtensionClassLoader> classLoaders = new HashMap<>();
|
||||||
private final Map<Extension, GeyserExtensionContainer> extensionContainers = new HashMap<>();
|
private final Map<Extension, GeyserExtensionContainer> extensionContainers = new HashMap<>();
|
||||||
|
private final Path extensionsDirectory = GeyserImpl.getInstance().getBootstrap().getConfigFolder().resolve("extensions");
|
||||||
|
|
||||||
public GeyserExtensionContainer loadExtension(Path path, GeyserExtensionDescription description) throws InvalidExtensionException {
|
public GeyserExtensionContainer loadExtension(Path path, GeyserExtensionDescription description) throws InvalidExtensionException {
|
||||||
if (path == null) {
|
if (path == null) {
|
||||||
|
@ -128,15 +128,15 @@ public class GeyserExtensionLoader extends ExtensionLoader {
|
||||||
@Override
|
@Override
|
||||||
protected void loadAllExtensions(@NonNull ExtensionManager extensionManager) {
|
protected void loadAllExtensions(@NonNull ExtensionManager extensionManager) {
|
||||||
try {
|
try {
|
||||||
if (Files.notExists(EXTENSION_DIRECTORY)) {
|
if (Files.notExists(extensionsDirectory)) {
|
||||||
Files.createDirectory(EXTENSION_DIRECTORY);
|
Files.createDirectory(extensionsDirectory);
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, Path> extensions = new LinkedHashMap<>();
|
Map<String, Path> extensions = new LinkedHashMap<>();
|
||||||
Map<String, GeyserExtensionContainer> loadedExtensions = new LinkedHashMap<>();
|
Map<String, GeyserExtensionContainer> loadedExtensions = new LinkedHashMap<>();
|
||||||
|
|
||||||
Pattern[] extensionFilters = this.extensionFilters();
|
Pattern[] extensionFilters = this.extensionFilters();
|
||||||
try (Stream<Path> entries = Files.walk(EXTENSION_DIRECTORY)) {
|
try (Stream<Path> entries = Files.walk(extensionsDirectory)) {
|
||||||
entries.forEach(path -> {
|
entries.forEach(path -> {
|
||||||
if (Files.isDirectory(path)) {
|
if (Files.isDirectory(path)) {
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in a new issue