From f39ae48db1e49aa93829064862886168f765ea53 Mon Sep 17 00:00:00 2001 From: Player Date: Fri, 1 Apr 2022 12:36:26 +0200 Subject: [PATCH] Add system properties to bypass ServiceLoader mixin service discovery. Workaround for https://github.com/SpongePowered/Mixin/issues/569 --- .../asm/service/MixinService.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/src/main/java/org/spongepowered/asm/service/MixinService.java b/src/main/java/org/spongepowered/asm/service/MixinService.java index a6b871620..d4a752e2d 100644 --- a/src/main/java/org/spongepowered/asm/service/MixinService.java +++ b/src/main/java/org/spongepowered/asm/service/MixinService.java @@ -144,6 +144,21 @@ private MixinService() { } private void runBootServices() { + // bypass service loader if the mixin.bootstrapService system property yields the desired IMixinServiceBootstrap implementation directly + String serviceCls = System.getProperty("mixin.bootstrapService"); + + if (serviceCls != null) { + try { + IMixinServiceBootstrap bootService = (IMixinServiceBootstrap) Class.forName(serviceCls).getConstructor().newInstance(); + bootService.bootstrap(); + bootedServices.add(bootService.getServiceClassName()); + + return; + } catch (ReflectiveOperationException e) { + throw new RuntimeException(e); + } + } + this.bootstrapServiceLoader = ServiceLoader.load(IMixinServiceBootstrap.class, this.getClass().getClassLoader()); Iterator iter = this.bootstrapServiceLoader.iterator(); while (iter.hasNext()) { @@ -200,6 +215,20 @@ private synchronized IMixinService getServiceInstance() { } private IMixinService initService() { + // bypass service loader if the mixin.service system property yields the desired IMixinService implementation directly + String serviceCls = System.getProperty("mixin.service"); // FIXME: there is overlap with bootedServices, may just use that directly? + + if (serviceCls != null) { + try { + IMixinService service = (IMixinService) Class.forName(serviceCls).getConstructor().newInstance(); + if (!service.isValid()) throw new RuntimeException("invalid service "+serviceCls+" configured via system property"); + + return service; + } catch (ReflectiveOperationException e) { + throw new RuntimeException(e); + } + } + this.serviceLoader = ServiceLoader.load(IMixinService.class, this.getClass().getClassLoader()); Iterator iter = this.serviceLoader.iterator(); List badServices = new ArrayList();