diff --git a/README.md b/README.md index acfde5ab1..d0d13d639 100644 --- a/README.md +++ b/README.md @@ -9,25 +9,25 @@ Fabric API is the library for essential hooks and interoperability mechanisms fo For support, consider joining the [Legacy Fabric discord server](https://legacyfabric.net/discord) or opening an issue. ## Modules available and tested by minecraft version -✅ = Working as expected\ +✅ = Working as expected.\ ⚠ = Working but has some issues.\ -? = Not sure if it was tested or working correctly\ -❌ = Not working at all, likely crashing +? = Not tested, might not work as intended.\ +❌ = Not ported or probably not working. -| | 1.7.10 | 1.8 | 1.8.9 | 1.9.4 | 1.10.2 | 1.11.2 | 1.12.2 | 1.13.2 | -|----------------------|--------|-----|-------|-------|--------|--------|--------|--------| -| api-base | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | -| command-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| command-api-v2 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| crash-report-info-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | -| entity-events-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| gamerule-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ? | -| item-groups-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| keybindings-api-v1 | ⚠ #132 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| lifecycle-events-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| logger-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | -| networking-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| permissions-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| registry-sync-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| rendering-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | -| resource-loader-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| | 1.6.4 | 1.7.10 | 1.8 | 1.8.9 | 1.9.4 | 1.10.2 | 1.11.2 | 1.12.2 | 1.13.2 | +|----------------------|-------------------------------|--------|-----|-------|-------|--------|--------|--------|--------| +| api-base | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | +| command-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| command-api-v2 | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| crash-report-info-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | +| entity-events-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| gamerule-api-v1 | ? | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ? | +| item-groups-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| keybindings-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| lifecycle-events-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| logger-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | +| networking-api-v1 | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| permissions-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| registry-sync-api-v1 | ❌ (Depends on networking-api) | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| rendering-api-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | +| resource-loader-v1 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | diff --git a/build.gradle b/build.gradle index 6562426c4..b2360176e 100644 --- a/build.gradle +++ b/build.gradle @@ -22,7 +22,8 @@ def supportedVersions = [ "1.9.4", "1.8.9", "1.8", - "1.7.10" + "1.7.10", + "1.6.4" ] def supportedRanges = [ // ["1.8", "1.8.9", false] // third parameter is whether or not to include snapshots in the range. diff --git a/gradle.properties b/gradle.properties index 625eedbdb..b3706e1d6 100644 --- a/gradle.properties +++ b/gradle.properties @@ -7,17 +7,17 @@ yarn_mappings_build = 530 ## Module versions legacy-fabric-api-base.version = 1.1.0 -legacy-fabric-command-api-v1.version = 1.0.0 +legacy-fabric-command-api-v1.version = 1.0.1 legacy-fabric-command-api-v2.version = 1.0.2 legacy-fabric-crash-report-info-v1.version = 1.0.0 legacy-fabric-entity-events-v1.version = 1.0.0 legacy-fabric-gamerule-api-v1.version = 1.0.0 -legacy-fabric-item-groups-v1.version = 2.0.0 -legacy-fabric-keybindings-api-v1.version = 1.0.1 -legacy-fabric-lifecycle-events-v1.version = 1.0.1 +legacy-fabric-item-groups-v1.version = 2.1.0 +legacy-fabric-keybindings-api-v1.version = 1.0.2 +legacy-fabric-lifecycle-events-v1.version = 1.1.0 legacy-fabric-logger-api-v1.version = 1.0.4 -legacy-fabric-networking-api-v1.version = 2.0.1 -legacy-fabric-permissions-api-v1.version = 1.0.1 +legacy-fabric-networking-api-v1.version = 2.0.2 +legacy-fabric-permissions-api-v1.version = 1.1.0 legacy-fabric-registry-sync-api-v1.version = 2.2.0 legacy-fabric-rendering-api-v1.version = 1.0.0 -legacy-fabric-resource-loader-v1.version = 2.1.1 +legacy-fabric-resource-loader-v1.version = 2.2.0 diff --git a/legacy-fabric-command-api-v1/common/gradle.properties b/legacy-fabric-command-api-v1/common/gradle.properties index 44fc6796f..900b11120 100644 --- a/legacy-fabric-command-api-v1/common/gradle.properties +++ b/legacy-fabric-command-api-v1/common/gradle.properties @@ -1,2 +1,3 @@ +minVersionIncluded=1.3 maxVersionIncluded=1.12.2 artifactSuffix= diff --git a/legacy-fabric-command-api-v1/common/src/main/resources/fabric.mod.json b/legacy-fabric-command-api-v1/common/src/main/resources/fabric.mod.json index 5611e7bde..f16165af2 100644 --- a/legacy-fabric-command-api-v1/common/src/main/resources/fabric.mod.json +++ b/legacy-fabric-command-api-v1/common/src/main/resources/fabric.mod.json @@ -22,7 +22,8 @@ ], "description": "Adds command-related hooks.", "depends": { - "minecraft": "${minecraft_version}" + "minecraft": "${minecraft_version}", + "legacy-fabric-lifecycle-events-v1-common": "*" }, "custom": { "modmenu": { diff --git a/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/CommandV1Test.java b/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/CommandV1Test.java new file mode 100644 index 000000000..390a8a7ab --- /dev/null +++ b/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/CommandV1Test.java @@ -0,0 +1,32 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.command; + +import net.fabricmc.api.ModInitializer; + +import net.legacyfabric.fabric.api.logger.v1.Logger; +import net.legacyfabric.fabric.api.registry.CommandRegistry; + +public class CommandV1Test implements ModInitializer { + public static final Logger LOGGER = Logger.get("LegacyFabricAPI", "Test", "CommandV1Test"); + + @Override + public void onInitialize() { + CommandRegistry.INSTANCE.register(new ModMetadataCommandV1()); + } +} diff --git a/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/ModMetadataCommandV1.java b/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/ModMetadataCommandV1.java new file mode 100644 index 000000000..d37c38c81 --- /dev/null +++ b/legacy-fabric-command-api-v1/common/src/testmod/java/net/legacyfabric/fabric/test/command/ModMetadataCommandV1.java @@ -0,0 +1,79 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.command; + +import java.util.Optional; + +import net.minecraft.command.AbstractCommand; +import net.minecraft.command.CommandException; +import net.minecraft.command.CommandSource; + +import net.fabricmc.loader.api.FabricLoader; +import net.fabricmc.loader.api.ModContainer; +import net.fabricmc.loader.api.metadata.ContactInformation; + +public class ModMetadataCommandV1 extends AbstractCommand { + @Override + public String getCommandName() { + return "modmetadatav1"; + } + + @Override + public String getUsageTranslationKey(CommandSource source) { + return "modmetadatav1"; + } + + @Override + public void execute(CommandSource source, String[] args) throws CommandException { + if (args.length > 0) { + Optional optionalModContainer = FabricLoader.getInstance().getModContainer(args[0]); + + if (optionalModContainer.isPresent()) { + ModContainer container = optionalModContainer.get(); + + StringBuilder builder = new StringBuilder(); + builder.append("Mod Name: ".concat(container.getMetadata().getName()).concat("\n")); + builder.append("Description: ".concat(container.getMetadata().getDescription()).concat("\n")); + ContactInformation contact = container.getMetadata().getContact(); + + if (contact.get("issues").isPresent()) { + StringBuilder issueText = new StringBuilder(""); + issueText.append("Issues: "); + StringBuilder issueUrl = new StringBuilder(contact.get("issues").get()); + issueText.append(issueUrl); + issueText.append("\n"); + builder.append(issueText); + } + + if (contact.get("sources").isPresent()) { + StringBuilder sourcesText = new StringBuilder(""); + sourcesText.append("Sources: "); + StringBuilder sourcesUrl = new StringBuilder(contact.get("sources").get()); + sourcesText.append(sourcesUrl); + sourcesText.append("\n"); + builder.append(sourcesText); + } + + builder.append("Metadata Type: ".concat(container.getMetadata().getType()).concat("\n")); + CommandV1Test.LOGGER.info(builder.toString()); + } else { + CommandV1Test.LOGGER.error("Couldn't find Mod container for mod id '" + args[0] + "'"); + } + } + } +} diff --git a/legacy-fabric-command-api-v1/common/src/testmod/resources/fabric.mod.json b/legacy-fabric-command-api-v1/common/src/testmod/resources/fabric.mod.json new file mode 100644 index 000000000..7af4a7f70 --- /dev/null +++ b/legacy-fabric-command-api-v1/common/src/testmod/resources/fabric.mod.json @@ -0,0 +1,14 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-command-api-v1-testmod", + "description": "Tests for api features", + "version": "1.0.0", + "entrypoints": { + "main": [ + "net.legacyfabric.fabric.test.command.CommandV1Test" + ] + }, + "depends": { + "minecraft": "${minecraft_version}" + } +} diff --git a/legacy-fabric-command-api-v2/1.7.10/gradle.properties b/legacy-fabric-command-api-v2/1.7.10/gradle.properties index c6dcd9541..af031afbf 100644 --- a/legacy-fabric-command-api-v2/1.7.10/gradle.properties +++ b/legacy-fabric-command-api-v2/1.7.10/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.7.10 diff --git a/legacy-fabric-item-groups-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java b/legacy-fabric-item-groups-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java new file mode 100644 index 000000000..151346441 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.item.group.client; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; + +import net.minecraft.client.gui.screen.Screen; + +import net.legacyfabric.fabric.impl.item.group.ScreenAccessor; + +@Mixin(Screen.class) +public abstract class MixinScreen implements ScreenAccessor { + @Shadow + public abstract void renderTooltip(String text, int x, int y); + + @Override + public void callRenderTooltip(String text, int x, int y) { + this.renderTooltip(text, x, y); + } +} diff --git a/legacy-fabric-item-groups-v1/1.12.2/src/main/resources/legacy-fabric-item-groups-v1.mixins.json b/legacy-fabric-item-groups-v1/1.12.2/src/main/resources/legacy-fabric-item-groups-v1.mixins.json index f0b4add64..4302b11d7 100644 --- a/legacy-fabric-item-groups-v1/1.12.2/src/main/resources/legacy-fabric-item-groups-v1.mixins.json +++ b/legacy-fabric-item-groups-v1/1.12.2/src/main/resources/legacy-fabric-item-groups-v1.mixins.json @@ -6,6 +6,7 @@ "ItemGroupMixin" ], "client": [ + "client.MixinScreen" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-item-groups-v1/1.6.4/build.gradle b/legacy-fabric-item-groups-v1/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacy-fabric-item-groups-v1/1.6.4/gradle.properties b/legacy-fabric-item-groups-v1/1.6.4/gradle.properties new file mode 100644 index 000000000..72b74abca --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.3 +maxVersionIncluded=1.6.4 diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/item/group/FabricItemGroup.java b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/item/group/FabricItemGroup.java new file mode 100644 index 000000000..4ff47d1d9 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/item/group/FabricItemGroup.java @@ -0,0 +1,57 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.impl.item.group; + +import java.util.List; +import java.util.function.BiConsumer; +import java.util.function.Supplier; + +import net.minecraft.item.Item; +import net.minecraft.item.ItemStack; +import net.minecraft.item.itemgroup.ItemGroup; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +public class FabricItemGroup extends ItemGroup { + private final Supplier itemSupplier; + private final BiConsumer, ItemGroup> stacksForDisplay; + + public FabricItemGroup(int index, String id, Supplier itemSupplier, BiConsumer, ItemGroup> stacksForDisplay) { + super(index, id); + this.itemSupplier = itemSupplier; + this.stacksForDisplay = stacksForDisplay; + } + + @Override + @Environment(EnvType.CLIENT) + public Item method_3320() { + return this.itemSupplier.get().getItem(); + } + + @Override + @Environment(EnvType.CLIENT) + public void showItems(List stacks) { + if (stacksForDisplay != null) { + stacksForDisplay.accept(stacks, this); + return; + } + + super.showItems(stacks); + } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/ItemGroupMixin.java b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/ItemGroupMixin.java new file mode 100644 index 000000000..5eb3f5ebe --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/ItemGroupMixin.java @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.item.group; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.item.itemgroup.ItemGroup; + +import net.legacyfabric.fabric.impl.item.group.FabricCreativeGuiComponents; +import net.legacyfabric.fabric.impl.item.group.FabricItemGroup; + +@Mixin(ItemGroup.class) +public class ItemGroupMixin { + @Inject(method = "", at = @At("RETURN")) + private static void classInit(CallbackInfo ci) { + FabricCreativeGuiComponents.ITEM_GROUP_CREATOR = FabricItemGroup::new; + } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/HandledScreenMixin.java b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/HandledScreenMixin.java new file mode 100644 index 000000000..14d8ccf80 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/HandledScreenMixin.java @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.item.group.client; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; + +import net.minecraft.client.gui.screen.ingame.HandledScreen; + +import net.legacyfabric.fabric.impl.item.group.ScreenAccessor; + +@Mixin(HandledScreen.class) +public abstract class HandledScreenMixin implements ScreenAccessor { + @Shadow + protected abstract void method_1128(String par1, int par2, int par3); + + @Override + public void callRenderTooltip(String text, int x, int y) { + this.method_1128(text, x, y); + } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png new file mode 100644 index 000000000..2931efbf6 Binary files /dev/null and b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png differ diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/textures/gui/creative_buttons.png b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/textures/gui/creative_buttons.png new file mode 100644 index 000000000..27b9a1499 Binary files /dev/null and b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/assets/legacy-fabric/textures/gui/creative_buttons.png differ diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/fabric.mod.json b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..ab1f44bd4 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,37 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-item-groups-v1", + "name": "Legacy Fabric Item Groups (V1)", + "version": "${version}", + "environment": "*", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric/icon.png", + "contact": { + "homepage": "https://legacyfabric.net/", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + "FabricMC", + "Legacy Fabric" + ], + "mixins": [ + "legacy-fabric-item-groups-v1.mixins.json" + ], + "description": "Advanced item groups.", + "depends": { + "minecraft": "${minecraft_version}" + }, + "custom": { + "modmenu": { + "badges": [ "library" ], + "parent": { + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "badges": [ "library" ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2.", + "icon": "assets/legacy-fabric/icon.png" + } + } + } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/legacy-fabric-item-groups-v1.mixins.json b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/legacy-fabric-item-groups-v1.mixins.json new file mode 100644 index 000000000..926003ea4 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/main/resources/legacy-fabric-item-groups-v1.mixins.json @@ -0,0 +1,14 @@ +{ + "required": true, + "package": "net.legacyfabric.fabric.mixin.item.group", + "compatibilityLevel": "JAVA_8", + "mixins": [ + "ItemGroupMixin" + ], + "client": [ + "client.HandledScreenMixin" + ], + "injectors": { + "defaultRequire": 1 + } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/item/group/ItemGroupTest.java b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/item/group/ItemGroupTest.java new file mode 100644 index 000000000..3adb96689 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/item/group/ItemGroupTest.java @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.item.group; + +import java.util.Arrays; +import java.util.Objects; +import java.util.stream.StreamSupport; + +import net.minecraft.item.Item; +import net.minecraft.item.ItemStack; +import net.minecraft.item.itemgroup.ItemGroup; + +import net.fabricmc.api.ModInitializer; + +import net.legacyfabric.fabric.api.client.itemgroup.FabricItemGroupBuilder; +import net.legacyfabric.fabric.api.util.Identifier; + +public class ItemGroupTest implements ModInitializer { + //Adds an item group with all items in it + private static final ItemGroup ITEM_GROUP = FabricItemGroupBuilder.create(new Identifier("legacy-fabric-item-groups-v1-testmod", "test_group")) + .iconWithItemStack(() -> new ItemStack(Item.DIAMOND)) + .appendItems(stacks -> + StreamSupport.stream(Arrays.stream(Item.ITEMS).spliterator(), false) + .filter(Objects::nonNull) + .map(ItemStack::new) + .forEach(stacks::add) + ).build(); + + private static final ItemGroup ITEM_GROUP_2 = FabricItemGroupBuilder.create(new Identifier("legacy-fabric-item-groups-v1-testmod", "test_group_two")) + .iconWithItemStack(() -> new ItemStack(Item.REDSTONE)) + .appendItems((stacks, itemGroup) -> { + for (Item item : Item.ITEMS) { + if (item != null && (item.getItemGroup() == ItemGroup.FOOD || item.getItemGroup() == itemGroup)) { + stacks.add(new ItemStack(item)); + } + } + }).build(); + + @Override + public void onInitialize() { } +} diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/assets/legacy-fabric-api/lang/en_US.lang b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/assets/legacy-fabric-api/lang/en_US.lang new file mode 100644 index 000000000..92e649b84 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/assets/legacy-fabric-api/lang/en_US.lang @@ -0,0 +1 @@ +itemGroup.dmn.testgroup=Test Group by DomamaN202 diff --git a/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/fabric.mod.json b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/fabric.mod.json new file mode 100644 index 000000000..ffa7dbef4 --- /dev/null +++ b/legacy-fabric-item-groups-v1/1.6.4/src/testmod/resources/fabric.mod.json @@ -0,0 +1,14 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-item-groups-v0-testmod", + "description": "Tests for Item Groups", + "version": "1.0.0", + "entrypoints": { + "main": [ + "net.legacyfabric.fabric.test.item.group.ItemGroupTest" + ] + }, + "depends": { + "minecraft": "${minecraft_version}" + } +} diff --git a/legacy-fabric-item-groups-v1/1.8.9/gradle.properties b/legacy-fabric-item-groups-v1/1.8.9/gradle.properties index 7a09d76fd..3b74ec5e2 100644 --- a/legacy-fabric-item-groups-v1/1.8.9/gradle.properties +++ b/legacy-fabric-item-groups-v1/1.8.9/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.10.2 diff --git a/legacy-fabric-item-groups-v1/common/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java b/legacy-fabric-item-groups-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java similarity index 100% rename from legacy-fabric-item-groups-v1/common/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java rename to legacy-fabric-item-groups-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/item/group/client/MixinScreen.java diff --git a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/en_US.lang b/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/en_US.lang deleted file mode 100644 index c82f116d6..000000000 --- a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/en_US.lang +++ /dev/null @@ -1 +0,0 @@ -fabric.gui.creativeTabPage=Page %d/%d diff --git a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/ru_RU.lang b/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/ru_RU.lang deleted file mode 100644 index 31292b1be..000000000 --- a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/assets/legacy-fabric/lang/ru_RU.lang +++ /dev/null @@ -1 +0,0 @@ -fabric.gui.creativeTabPage=Страница %d/%d diff --git a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/legacy-fabric-item-groups-v1.mixins.json b/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/legacy-fabric-item-groups-v1.mixins.json index f0b4add64..4302b11d7 100644 --- a/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/legacy-fabric-item-groups-v1.mixins.json +++ b/legacy-fabric-item-groups-v1/1.8.9/src/main/resources/legacy-fabric-item-groups-v1.mixins.json @@ -6,6 +6,7 @@ "ItemGroupMixin" ], "client": [ + "client.MixinScreen" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-item-groups-v1/common/src/main/resources/legacy-fabric-item-groups-v1-common.mixins.json b/legacy-fabric-item-groups-v1/common/src/main/resources/legacy-fabric-item-groups-v1-common.mixins.json index 1f9907d0b..b0ead9873 100644 --- a/legacy-fabric-item-groups-v1/common/src/main/resources/legacy-fabric-item-groups-v1-common.mixins.json +++ b/legacy-fabric-item-groups-v1/common/src/main/resources/legacy-fabric-item-groups-v1-common.mixins.json @@ -7,8 +7,7 @@ ], "client": [ "client.MixinCreativePlayerInventoryGui", - "client.MixinItemGroup", - "client.MixinScreen" + "client.MixinItemGroup" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-keybindings-api-v1/1.6.4/build.gradle b/legacy-fabric-keybindings-api-v1/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacy-fabric-keybindings-api-v1/1.6.4/gradle.properties b/legacy-fabric-keybindings-api-v1/1.6.4/gradle.properties new file mode 100644 index 000000000..72b74abca --- /dev/null +++ b/legacy-fabric-keybindings-api-v1/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.3 +maxVersionIncluded=1.6.4 diff --git a/legacy-fabric-keybindings-api-v1/1.6.4/src/main/resources/fabric.mod.json b/legacy-fabric-keybindings-api-v1/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..17813b87b --- /dev/null +++ b/legacy-fabric-keybindings-api-v1/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,35 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-keybinding-api-v1", + "name": "Legacy Fabric Keybinding API (V1)", + "version": "${version}", + "environment": "client", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric-api/icon.png", + "contact": { + "homepage": "https://legacyfabric.net/", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + "Legacy Fabric", + "FabricMC" + ], + "depends": { + "minecraft": "${minecraft_version}" + }, + "mixins": [], + "description": "Hooks that help adding keybindings", + "custom": { + "modmenu": { + "badges": [ "library" ], + "parent": { + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "badges": [ "library" ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2.", + "icon": "assets/legacy-fabric-api/icon.png" + } + } + } +} diff --git a/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/client/keybinding/KeybindingTest.java b/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/client/keybinding/KeybindingTest.java new file mode 100644 index 000000000..bcb65a476 --- /dev/null +++ b/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/client/keybinding/KeybindingTest.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.client.keybinding; + +import org.lwjgl.input.Keyboard; + +import net.minecraft.client.option.KeyBinding; + +import net.fabricmc.api.ClientModInitializer; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientTickEvents; +import net.legacyfabric.fabric.api.client.keybinding.v1.KeyBindingHelper; + +public class KeybindingTest implements ClientModInitializer { + @Override + public void onInitializeClient() { + KeyBinding keyBinding = KeyBindingHelper.registerKeyBinding(new KeyBinding("api.keybinding.testTranslationKey", Keyboard.KEY_F)); + ClientTickEvents.END_CLIENT_TICK.register(client -> { + if (keyBinding.wasPressed()) { + System.out.printf("The key %s was pressed%n", Keyboard.getKeyName(keyBinding.code)); + } + }); + } +} diff --git a/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/resources/fabric.mod.json b/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/resources/fabric.mod.json new file mode 100644 index 000000000..0033bc2ec --- /dev/null +++ b/legacy-fabric-keybindings-api-v1/1.6.4/src/testmod/resources/fabric.mod.json @@ -0,0 +1,16 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-keybinding-api-v1-testmod", + "description": "Tests for keybindings", + "version": "1.0.0", + "entrypoints": { + "client": [ + "net.legacyfabric.fabric.test.client.keybinding.KeybindingTest" + ] + }, + "depends": { + "minecraft": "${minecraft_version}", + "legacy-fabric-keybinding-api-v1": "*", + "legacy-fabric-lifecycle-events-v1-common": "*" + } +} diff --git a/legacy-fabric-keybindings-api-v1/1.7.10/gradle.properties b/legacy-fabric-keybindings-api-v1/1.7.10/gradle.properties index c6dcd9541..af031afbf 100644 --- a/legacy-fabric-keybindings-api-v1/1.7.10/gradle.properties +++ b/legacy-fabric-keybindings-api-v1/1.7.10/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.7.10 diff --git a/legacy-fabric-keybindings-api-v1/1.7.10/src/testmod/resources/fabric.mod.json b/legacy-fabric-keybindings-api-v1/1.7.10/src/testmod/resources/fabric.mod.json index b9c55e26f..0033bc2ec 100644 --- a/legacy-fabric-keybindings-api-v1/1.7.10/src/testmod/resources/fabric.mod.json +++ b/legacy-fabric-keybindings-api-v1/1.7.10/src/testmod/resources/fabric.mod.json @@ -9,6 +9,8 @@ ] }, "depends": { - "minecraft": "${minecraft_version}" + "minecraft": "${minecraft_version}", + "legacy-fabric-keybinding-api-v1": "*", + "legacy-fabric-lifecycle-events-v1-common": "*" } } diff --git a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java new file mode 100644 index 000000000..11dd84134 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.client.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.client.MinecraftClient; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientLifecycleEvents; + +@Environment(EnvType.CLIENT) +@Mixin(MinecraftClient.class) +public class MinecraftClientMixin { + @Inject(at = @At(value = "INVOKE", target = "Lorg/apache/logging/log4j/Logger;info(Ljava/lang/String;)V", shift = At.Shift.AFTER, remap = false), method = "stop") + private void api$onStopping(CallbackInfo ci) { + ClientLifecycleEvents.CLIENT_STOPPING.invoker().onClientStopping((MinecraftClient) (Object) this); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java index af6bc7fe5..cc904578f 100644 --- a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java +++ b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java @@ -21,11 +21,14 @@ import org.spongepowered.asm.mixin.Shadow; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.Slice; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import net.minecraft.server.MinecraftServer; import net.minecraft.server.world.ServerWorld; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerLifecycleEvents; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerTickEvents; import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerWorldEvents; @Mixin(MinecraftServer.class) @@ -33,10 +36,27 @@ public abstract class MinecraftServerMixin { @Shadow public ServerWorld[] worlds; + @Inject(at = @At("HEAD"), method = "saveWorlds") + public void api$serverWorldUnload(boolean silent, CallbackInfo ci) { + for (ServerWorld world : this.worlds) { + ServerWorldEvents.UNLOAD.invoker().onWorldUnload((MinecraftServer) (Object) this, world); + } + } + @Inject(at = @At(value = "TAIL"), method = "prepareWorlds") public void serverWorldLoad(CallbackInfo ci) { for (ServerWorld world : this.worlds) { ServerWorldEvents.LOAD.invoker().onWorldLoad((MinecraftServer) (Object) this, world); } } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J"), method = "run", slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V"))) + public void api$startServerTick(CallbackInfo ci) { + ServerTickEvents.START_SERVER_TICK.invoker().onStartTick((MinecraftServer) (Object) this); + } + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V", shift = At.Shift.AFTER), method = "run") + public void api$afterServerStart(CallbackInfo ci) { + ServerLifecycleEvents.SERVER_STARTED.invoker().onServerStarted((MinecraftServer) (Object) this); + } } diff --git a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java new file mode 100644 index 000000000..c55f346f7 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.versioned; + +import org.spongepowered.asm.mixin.Final; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +import net.minecraft.server.world.ServerWorld; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.ServerChunkProvider; + +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerChunkEvents; + +@Mixin(ServerChunkProvider.class) +public class ServerChunkProviderMixin { + @Final + @Shadow + private ServerWorld world; + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/chunk/ChunkStorage;writeChunk(Lnet/minecraft/world/World;Lnet/minecraft/world/chunk/Chunk;)V"), method = "saveChunk") + public void api$chunkUnload(Chunk chunk, CallbackInfo ci) { + ServerChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload(this.world, chunk); + } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/chunk/ChunkStorage;loadChunk(Lnet/minecraft/world/World;II)Lnet/minecraft/world/chunk/Chunk;"), method = "loadChunk", locals = LocalCapture.CAPTURE_FAILEXCEPTION) + public void api$chunkLoad(int x, int z, CallbackInfoReturnable cir, Chunk chunk) { + ServerChunkEvents.CHUNK_LOAD.invoker().onChunkLoad(this.world, chunk); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json index 252c7673a..381cfac59 100644 --- a/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json +++ b/legacy-fabric-lifecycle-events-v1/1.12.2/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json @@ -3,10 +3,12 @@ "package": "net.legacyfabric.fabric.mixin.event.lifecycle", "compatibilityLevel": "JAVA_8", "mixins": [ - "versioned.MinecraftServerMixin" + "versioned.MinecraftServerMixin", + "versioned.ServerChunkProviderMixin" ], "client": [ - "client.versioned.ClientChunkProviderMixin" + "client.versioned.ClientChunkProviderMixin", + "client.versioned.MinecraftClientMixin" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-lifecycle-events-v1/1.12.2/src/testmod/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/1.12.2/src/testmod/resources/fabric.mod.json index e53297411..3ff8b8978 100644 --- a/legacy-fabric-lifecycle-events-v1/1.12.2/src/testmod/resources/fabric.mod.json +++ b/legacy-fabric-lifecycle-events-v1/1.12.2/src/testmod/resources/fabric.mod.json @@ -1,6 +1,6 @@ { "schemaVersion": 1, - "id": "legacy-fabric-lifecycle-events-v1-testmod-1-8-9", + "id": "legacy-fabric-lifecycle-events-v1-testmod", "description": "Tests for lifecycle events", "version": "1.0.0", "entrypoints": { diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/build.gradle b/legacy-fabric-lifecycle-events-v1/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/gradle.properties b/legacy-fabric-lifecycle-events-v1/1.6.4/gradle.properties new file mode 100644 index 000000000..72b74abca --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.3 +maxVersionIncluded=1.6.4 diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/ClientChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/ClientChunkProviderMixin.java new file mode 100644 index 000000000..c9ec3a52d --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/ClientChunkProviderMixin.java @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.client.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.client.world.ClientWorld; +import net.minecraft.world.World; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.ClientChunkProvider; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientChunkEvents; + +@Environment(EnvType.CLIENT) +@Mixin(ClientChunkProvider.class) +public abstract class ClientChunkProviderMixin { + @Shadow + private World world; + + @Shadow + public abstract Chunk getChunk(int i, int j); + + @Inject(at = @At("RETURN"), method = "unloadChunk") + public void api$chunkUnload(int i, int j, CallbackInfo ci) { + ClientChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload((ClientWorld) this.world, this.getChunk(i, j)); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java new file mode 100644 index 000000000..143f0ed62 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.client.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.client.MinecraftClient; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientLifecycleEvents; + +@Environment(EnvType.CLIENT) +@Mixin(MinecraftClient.class) +public class MinecraftClientMixin { + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/util/logging/LogManager;info(Ljava/lang/String;)V", shift = At.Shift.AFTER), method = "stop") + private void api$onStopping(CallbackInfo ci) { + ClientLifecycleEvents.CLIENT_STOPPING.invoker().onClientStopping((MinecraftClient) (Object) this); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java new file mode 100644 index 000000000..7c0d32b3d --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.Slice; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.server.MinecraftServer; +import net.minecraft.server.world.ServerWorld; + +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerLifecycleEvents; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerTickEvents; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerWorldEvents; + +@Mixin(MinecraftServer.class) +public abstract class MinecraftServerMixin { + @Shadow + public ServerWorld[] worlds; + + @Inject(at = @At("HEAD"), method = "saveWorlds") + public void api$serverWorldUnload(boolean silent, CallbackInfo ci) { + for (ServerWorld world : this.worlds) { + ServerWorldEvents.UNLOAD.invoker().onWorldUnload((MinecraftServer) (Object) this, world); + } + } + + @Inject(at = @At(value = "TAIL"), method = "method_2980") + public void api$serverWorldLoad(CallbackInfo ci) { + for (ServerWorld world : this.worlds) { + ServerWorldEvents.LOAD.invoker().onWorldLoad((MinecraftServer) (Object) this, world); + } + } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J"), method = "run", slice = @Slice(from = @At(value = "FIELD", target = "Lnet/minecraft/server/MinecraftServer;running:Z"))) + public void api$startServerTick(CallbackInfo ci) { + ServerTickEvents.START_SERVER_TICK.invoker().onStartTick((MinecraftServer) (Object) this); + } + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J", ordinal = 0, shift = At.Shift.AFTER), method = "run") + public void api$afterServerStart(CallbackInfo ci) { + ServerLifecycleEvents.SERVER_STARTED.invoker().onServerStarted((MinecraftServer) (Object) this); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java new file mode 100644 index 000000000..72cd96ffd --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +import net.minecraft.server.world.ServerWorld; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.ServerChunkProvider; + +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerChunkEvents; + +@Mixin(ServerChunkProvider.class) +public class ServerChunkProviderMixin { + @Shadow + private ServerWorld world; + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/chunk/ChunkStorage;writeChunk(Lnet/minecraft/world/World;Lnet/minecraft/world/chunk/Chunk;)V"), method = "method_2128") + public void api$chunkUnload(Chunk chunk, CallbackInfo ci) { + ServerChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload(this.world, chunk); + } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/chunk/ChunkStorage;loadChunk(Lnet/minecraft/world/World;II)Lnet/minecraft/world/chunk/Chunk;"), method = "method_2129", locals = LocalCapture.CAPTURE_FAILEXCEPTION) + public void api$chunkLoad(int x, int z, CallbackInfoReturnable cir, Chunk chunk) { + ServerChunkEvents.CHUNK_LOAD.invoker().onChunkLoad(this.world, chunk); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png new file mode 100644 index 000000000..2931efbf6 Binary files /dev/null and b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png differ diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..f8b664e41 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,37 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-lifecycle-events-v1", + "name": "Legacy Fabric Lifecycle Events (V1)", + "version": "${version}", + "environment": "*", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric/icon.png", + "contact": { + "homepage": "https://legacy-fabric.github.io/", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + "Legacy-Fabric", + "FabricMC" + ], + "mixins": [ + "legacy-fabric-lifecycle-events-v1.mixins.json" + ], + "description": "Events for the game's lifecycle.", + "depends": { + "minecraft": "${minecraft_version}" + }, + "custom": { + "modmenu": { + "badges": [ "library" ], + "parent": { + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "badges": [ "library" ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2.", + "icon": "assets/legacy-fabric/icon.png" + } + } + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json new file mode 100644 index 000000000..381cfac59 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json @@ -0,0 +1,16 @@ +{ + "required": true, + "package": "net.legacyfabric.fabric.mixin.event.lifecycle", + "compatibilityLevel": "JAVA_8", + "mixins": [ + "versioned.MinecraftServerMixin", + "versioned.ServerChunkProviderMixin" + ], + "client": [ + "client.versioned.ClientChunkProviderMixin", + "client.versioned.MinecraftClientMixin" + ], + "injectors": { + "defaultRequire": 1 + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/lifecycle/client/ClientLifecycleEventsTest.java b/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/lifecycle/client/ClientLifecycleEventsTest.java new file mode 100644 index 000000000..bf1b8088e --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/lifecycle/client/ClientLifecycleEventsTest.java @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.lifecycle.client; + +import net.fabricmc.api.ClientModInitializer; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientLifecycleEvents; +import net.legacyfabric.fabric.api.logger.v1.Logger; +import net.legacyfabric.fabric.impl.logger.LoggerImpl; + +public class ClientLifecycleEventsTest implements ClientModInitializer { + private static final Logger LOGGER = Logger.get(LoggerImpl.API, "Test", "ClientLifecycleEvents"); + + @Override + public void onInitializeClient() { + ClientLifecycleEvents.CLIENT_STARTED.register(client -> { + LOGGER.info("Client started"); + }); + ClientLifecycleEvents.CLIENT_STOPPING.register(client -> { + LOGGER.info("Client stopping"); + }); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/resources/fabric.mod.json new file mode 100644 index 000000000..3ff8b8978 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.6.4/src/testmod/resources/fabric.mod.json @@ -0,0 +1,14 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-lifecycle-events-v1-testmod", + "description": "Tests for lifecycle events", + "version": "1.0.0", + "entrypoints": { + "client": [ + "net.legacyfabric.fabric.test.lifecycle.client.ClientLifecycleEventsTest" + ] + }, + "depends": { + "minecraft": "${minecraft_version}" + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/gradle.properties b/legacy-fabric-lifecycle-events-v1/1.7.10/gradle.properties index c6dcd9541..af031afbf 100644 --- a/legacy-fabric-lifecycle-events-v1/1.7.10/gradle.properties +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.7.10 diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java new file mode 100644 index 000000000..11dd84134 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.client.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.client.MinecraftClient; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientLifecycleEvents; + +@Environment(EnvType.CLIENT) +@Mixin(MinecraftClient.class) +public class MinecraftClientMixin { + @Inject(at = @At(value = "INVOKE", target = "Lorg/apache/logging/log4j/Logger;info(Ljava/lang/String;)V", shift = At.Shift.AFTER, remap = false), method = "stop") + private void api$onStopping(CallbackInfo ci) { + ClientLifecycleEvents.CLIENT_STOPPING.invoker().onClientStopping((MinecraftClient) (Object) this); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java index 415358a2f..fb9e12c5b 100644 --- a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java @@ -21,11 +21,14 @@ import org.spongepowered.asm.mixin.Shadow; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.Slice; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import net.minecraft.server.MinecraftServer; import net.minecraft.server.world.ServerWorld; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerLifecycleEvents; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerTickEvents; import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerWorldEvents; @Mixin(MinecraftServer.class) @@ -46,4 +49,14 @@ public abstract class MinecraftServerMixin { ServerWorldEvents.LOAD.invoker().onWorldLoad((MinecraftServer) (Object) this, world); } } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J"), method = "run", slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V"))) + public void api$startServerTick(CallbackInfo ci) { + ServerTickEvents.START_SERVER_TICK.invoker().onStartTick((MinecraftServer) (Object) this); + } + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V", shift = At.Shift.AFTER), method = "run") + public void api$afterServerStart(CallbackInfo ci) { + ServerLifecycleEvents.SERVER_STARTED.invoker().onServerStarted((MinecraftServer) (Object) this); + } } diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java new file mode 100644 index 000000000..f4aee8f97 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +import net.minecraft.server.world.ServerWorld; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.ServerChunkProvider; + +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerChunkEvents; + +@Mixin(ServerChunkProvider.class) +public class ServerChunkProviderMixin { + @Shadow + private ServerWorld world; + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/chunk/ChunkStorage;writeChunk(Lnet/minecraft/world/World;Lnet/minecraft/world/chunk/Chunk;)V"), method = "saveChunk") + public void api$chunkUnload(Chunk chunk, CallbackInfo ci) { + ServerChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload(this.world, chunk); + } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/chunk/ChunkStorage;loadChunk(Lnet/minecraft/world/World;II)Lnet/minecraft/world/chunk/Chunk;"), method = "loadChunk", locals = LocalCapture.CAPTURE_FAILEXCEPTION) + public void api$chunkLoad(int x, int z, CallbackInfoReturnable cir, Chunk chunk) { + ServerChunkEvents.CHUNK_LOAD.invoker().onChunkLoad(this.world, chunk); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json index 252c7673a..381cfac59 100644 --- a/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json @@ -3,10 +3,12 @@ "package": "net.legacyfabric.fabric.mixin.event.lifecycle", "compatibilityLevel": "JAVA_8", "mixins": [ - "versioned.MinecraftServerMixin" + "versioned.MinecraftServerMixin", + "versioned.ServerChunkProviderMixin" ], "client": [ - "client.versioned.ClientChunkProviderMixin" + "client.versioned.ClientChunkProviderMixin", + "client.versioned.MinecraftClientMixin" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-lifecycle-events-v1/1.7.10/src/testmod/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/1.7.10/src/testmod/resources/fabric.mod.json index e53297411..3ff8b8978 100644 --- a/legacy-fabric-lifecycle-events-v1/1.7.10/src/testmod/resources/fabric.mod.json +++ b/legacy-fabric-lifecycle-events-v1/1.7.10/src/testmod/resources/fabric.mod.json @@ -1,6 +1,6 @@ { "schemaVersion": 1, - "id": "legacy-fabric-lifecycle-events-v1-testmod-1-8-9", + "id": "legacy-fabric-lifecycle-events-v1-testmod", "description": "Tests for lifecycle events", "version": "1.0.0", "entrypoints": { diff --git a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java new file mode 100644 index 000000000..11dd84134 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/versioned/MinecraftClientMixin.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.client.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.client.MinecraftClient; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +import net.legacyfabric.fabric.api.client.event.lifecycle.v1.ClientLifecycleEvents; + +@Environment(EnvType.CLIENT) +@Mixin(MinecraftClient.class) +public class MinecraftClientMixin { + @Inject(at = @At(value = "INVOKE", target = "Lorg/apache/logging/log4j/Logger;info(Ljava/lang/String;)V", shift = At.Shift.AFTER, remap = false), method = "stop") + private void api$onStopping(CallbackInfo ci) { + ClientLifecycleEvents.CLIENT_STOPPING.invoker().onClientStopping((MinecraftClient) (Object) this); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java index 5ef61aeaa..d42aa62b8 100644 --- a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java +++ b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/MinecraftServerMixin.java @@ -21,11 +21,14 @@ import org.spongepowered.asm.mixin.Shadow; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.Slice; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import net.minecraft.server.MinecraftServer; import net.minecraft.server.world.ServerWorld; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerLifecycleEvents; +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerTickEvents; import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerWorldEvents; @Mixin(MinecraftServer.class) @@ -33,10 +36,27 @@ public abstract class MinecraftServerMixin { @Shadow public ServerWorld[] worlds; + @Inject(at = @At("HEAD"), method = "saveWorlds") + public void api$serverWorldUnload(boolean silent, CallbackInfo ci) { + for (ServerWorld world : this.worlds) { + ServerWorldEvents.UNLOAD.invoker().onWorldUnload((MinecraftServer) (Object) this, world); + } + } + @Inject(at = @At(value = "TAIL"), method = "method_2980") public void serverWorldLoad(CallbackInfo ci) { for (ServerWorld world : this.worlds) { ServerWorldEvents.LOAD.invoker().onWorldLoad((MinecraftServer) (Object) this, world); } } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J"), method = "run", slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V"))) + public void api$startServerTick(CallbackInfo ci) { + ServerTickEvents.START_SERVER_TICK.invoker().onStartTick((MinecraftServer) (Object) this); + } + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V", shift = At.Shift.AFTER), method = "run") + public void api$afterServerStart(CallbackInfo ci) { + ServerLifecycleEvents.SERVER_STARTED.invoker().onServerStarted((MinecraftServer) (Object) this); + } } diff --git a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java new file mode 100644 index 000000000..f4aee8f97 --- /dev/null +++ b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/versioned/ServerChunkProviderMixin.java @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.event.lifecycle.versioned; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +import net.minecraft.server.world.ServerWorld; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.ServerChunkProvider; + +import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerChunkEvents; + +@Mixin(ServerChunkProvider.class) +public class ServerChunkProviderMixin { + @Shadow + private ServerWorld world; + + @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/chunk/ChunkStorage;writeChunk(Lnet/minecraft/world/World;Lnet/minecraft/world/chunk/Chunk;)V"), method = "saveChunk") + public void api$chunkUnload(Chunk chunk, CallbackInfo ci) { + ServerChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload(this.world, chunk); + } + + @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/chunk/ChunkStorage;loadChunk(Lnet/minecraft/world/World;II)Lnet/minecraft/world/chunk/Chunk;"), method = "loadChunk", locals = LocalCapture.CAPTURE_FAILEXCEPTION) + public void api$chunkLoad(int x, int z, CallbackInfoReturnable cir, Chunk chunk) { + ServerChunkEvents.CHUNK_LOAD.invoker().onChunkLoad(this.world, chunk); + } +} diff --git a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json index 252c7673a..381cfac59 100644 --- a/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json +++ b/legacy-fabric-lifecycle-events-v1/1.8.9/src/main/resources/legacy-fabric-lifecycle-events-v1.mixins.json @@ -3,10 +3,12 @@ "package": "net.legacyfabric.fabric.mixin.event.lifecycle", "compatibilityLevel": "JAVA_8", "mixins": [ - "versioned.MinecraftServerMixin" + "versioned.MinecraftServerMixin", + "versioned.ServerChunkProviderMixin" ], "client": [ - "client.versioned.ClientChunkProviderMixin" + "client.versioned.ClientChunkProviderMixin", + "client.versioned.MinecraftClientMixin" ], "injectors": { "defaultRequire": 1 diff --git a/legacy-fabric-lifecycle-events-v1/1.8.9/src/testmod/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/1.8.9/src/testmod/resources/fabric.mod.json index e53297411..3ff8b8978 100644 --- a/legacy-fabric-lifecycle-events-v1/1.8.9/src/testmod/resources/fabric.mod.json +++ b/legacy-fabric-lifecycle-events-v1/1.8.9/src/testmod/resources/fabric.mod.json @@ -1,6 +1,6 @@ { "schemaVersion": 1, - "id": "legacy-fabric-lifecycle-events-v1-testmod-1-8-9", + "id": "legacy-fabric-lifecycle-events-v1-testmod", "description": "Tests for lifecycle events", "version": "1.0.0", "entrypoints": { diff --git a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/MinecraftServerMixin.java b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/MinecraftServerMixin.java index 1e31a6037..c7681e9fe 100644 --- a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/MinecraftServerMixin.java +++ b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/MinecraftServerMixin.java @@ -22,7 +22,6 @@ import org.spongepowered.asm.mixin.Shadow; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; -import org.spongepowered.asm.mixin.injection.Slice; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import net.minecraft.server.MinecraftServer; @@ -37,11 +36,6 @@ public class MinecraftServerMixin { @Shadow public ServerWorld[] worlds; - @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/server/MinecraftServer;getTimeMillis()J"), method = "run", slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V"))) - public void api$startServerTick(CallbackInfo ci) { - ServerTickEvents.START_SERVER_TICK.invoker().onStartTick((MinecraftServer) (Object) this); - } - @Inject(at = @At(value = "INVOKE", target = "Ljava/lang/Thread;sleep(J)V", remap = false), method = "run") public void api$endServerTick(CallbackInfo ci) { ServerTickEvents.END_SERVER_TICK.invoker().onEndTick((MinecraftServer) (Object) this); @@ -62,11 +56,6 @@ public class MinecraftServerMixin { ServerLifecycleEvents.SERVER_STARTING.invoker().onServerStarting((MinecraftServer) (Object) this); } - @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/server/MinecraftServer;setServerMeta(Lnet/minecraft/server/ServerMetadata;)V", shift = At.Shift.AFTER), method = "run") - public void api$afterServerStart(CallbackInfo ci) { - ServerLifecycleEvents.SERVER_STARTED.invoker().onServerStarted((MinecraftServer) (Object) this); - } - @Inject(at = @At("HEAD"), method = "saveWorlds") public void api$serverWorldUnload(boolean silent, CallbackInfo ci) { for (ServerWorld world : this.worlds) { diff --git a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/ServerChunkProviderMixin.java b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/ServerChunkProviderMixin.java index 5af0f7edb..6000e7798 100644 --- a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/ServerChunkProviderMixin.java +++ b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/ServerChunkProviderMixin.java @@ -18,31 +18,9 @@ package net.legacyfabric.fabric.mixin.event.lifecycle; import org.spongepowered.asm.mixin.Mixin; -import org.spongepowered.asm.mixin.Shadow; -import org.spongepowered.asm.mixin.injection.At; -import org.spongepowered.asm.mixin.injection.Inject; -import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; -import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; -import org.spongepowered.asm.mixin.injection.callback.LocalCapture; -import net.minecraft.server.world.ServerWorld; -import net.minecraft.world.chunk.Chunk; import net.minecraft.world.chunk.ServerChunkProvider; -import net.legacyfabric.fabric.api.event.lifecycle.v1.ServerChunkEvents; - @Mixin(ServerChunkProvider.class) public class ServerChunkProviderMixin { - @Shadow - private ServerWorld world; - - @Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/chunk/ChunkStorage;writeChunk(Lnet/minecraft/world/World;Lnet/minecraft/world/chunk/Chunk;)V"), method = "saveChunk") - public void api$chunkUnload(Chunk chunk, CallbackInfo ci) { - ServerChunkEvents.CHUNK_UNLOAD.invoker().onChunkUnload(this.world, chunk); - } - - @Inject(at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/chunk/ChunkStorage;loadChunk(Lnet/minecraft/world/World;II)Lnet/minecraft/world/chunk/Chunk;"), method = "loadChunk", locals = LocalCapture.CAPTURE_FAILEXCEPTION) - public void api$chunkLoad(int x, int z, CallbackInfoReturnable cir, Chunk chunk) { - ServerChunkEvents.CHUNK_LOAD.invoker().onChunkLoad(this.world, chunk); - } } diff --git a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/MinecraftClientMixin.java b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/MinecraftClientMixin.java index e408880b2..d4c63004f 100644 --- a/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/MinecraftClientMixin.java +++ b/legacy-fabric-lifecycle-events-v1/common/src/main/java/net/legacyfabric/fabric/mixin/event/lifecycle/client/MinecraftClientMixin.java @@ -43,11 +43,6 @@ public class MinecraftClientMixin { ClientTickEvents.END_CLIENT_TICK.invoker().onEndTick((MinecraftClient) (Object) this); } - @Inject(at = @At(value = "INVOKE", target = "Lorg/apache/logging/log4j/Logger;info(Ljava/lang/String;)V", shift = At.Shift.AFTER, remap = false), method = "stop") - private void api$onStopping(CallbackInfo ci) { - ClientLifecycleEvents.CLIENT_STOPPING.invoker().onClientStopping((MinecraftClient) (Object) this); - } - @Inject(at = @At(value = "RETURN"), method = "initializeGame") private void api$onStart(CallbackInfo ci) { ClientLifecycleEvents.CLIENT_STARTED.invoker().onClientStarted((MinecraftClient) (Object) this); diff --git a/legacy-fabric-lifecycle-events-v1/common/src/testmod/resources/fabric.mod.json b/legacy-fabric-lifecycle-events-v1/common/src/testmod/resources/fabric.mod.json index ac25a1d6f..23c4a9fab 100644 --- a/legacy-fabric-lifecycle-events-v1/common/src/testmod/resources/fabric.mod.json +++ b/legacy-fabric-lifecycle-events-v1/common/src/testmod/resources/fabric.mod.json @@ -1,6 +1,6 @@ { "schemaVersion": 1, - "id": "legacy-fabric-lifecycle-events-v1-testmod", + "id": "legacy-fabric-lifecycle-events-v1-common-testmod", "description": "Tests for lifecycle events", "version": "1.0.0", "entrypoints": { diff --git a/legacy-fabric-networking-api-v1/1.7.10/gradle.properties b/legacy-fabric-networking-api-v1/1.7.10/gradle.properties index 77baca0c7..af031afbf 100644 --- a/legacy-fabric-networking-api-v1/1.7.10/gradle.properties +++ b/legacy-fabric-networking-api-v1/1.7.10/gradle.properties @@ -1,2 +1,2 @@ -minVersionExcluded=1.6.4 +minVersionIncluded=1.7.10 maxVersionIncluded=1.7.10 diff --git a/legacy-fabric-networking-api-v1/common/gradle.properties b/legacy-fabric-networking-api-v1/common/gradle.properties index 197d3d229..503076051 100644 --- a/legacy-fabric-networking-api-v1/common/gradle.properties +++ b/legacy-fabric-networking-api-v1/common/gradle.properties @@ -1,2 +1,2 @@ -minVersionExcluded=1.6.4 +minVersionIncluded=1.7.10 maxVersionIncluded=1.12.2 diff --git a/legacy-fabric-permissions-api-v1/1.6.4/build.gradle b/legacy-fabric-permissions-api-v1/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacy-fabric-permissions-api-v1/1.6.4/gradle.properties b/legacy-fabric-permissions-api-v1/1.6.4/gradle.properties new file mode 100644 index 000000000..72b74abca --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.3 +maxVersionIncluded=1.6.4 diff --git a/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java b/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java new file mode 100644 index 000000000..af30c8179 --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.impl.permission; + +import net.minecraft.entity.player.ServerPlayerEntity; + +import net.fabricmc.api.ModInitializer; + +import net.legacyfabric.fabric.api.permission.v1.PermissionsApiHolder; +import net.legacyfabric.fabric.api.permission.v1.PlayerPermissionsApi; + +public class PermissionImpl implements ModInitializer { + @Override + public void onInitialize() { + PermissionsApiHolder.setFallbackPlayerPermissionsApi(FallbackPlayerPermissionsApi.INSTANCE); + } + + private enum FallbackPlayerPermissionsApi implements PlayerPermissionsApi { + INSTANCE; + + @Override + public String getId() { + return "legacy-fabric-fallback-permissions-api"; + } + + @Override + public boolean hasPermission(ServerPlayerEntity player, String perm) { + return player.server.getPlayerManager().canCheat(player.getUsername()); + } + } +} diff --git a/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/permission/CommandBlockExecutorMixin.java b/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/permission/CommandBlockExecutorMixin.java new file mode 100644 index 000000000..c492b5cbd --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/permission/CommandBlockExecutorMixin.java @@ -0,0 +1,32 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.permission; + +import org.spongepowered.asm.mixin.Mixin; + +import net.minecraft.block.entity.CommandBlockBlockEntity; + +import net.legacyfabric.fabric.api.permission.v1.PermissibleCommandSource; + +@Mixin(CommandBlockBlockEntity.class) +public abstract class CommandBlockExecutorMixin implements PermissibleCommandSource { + @Override + public boolean hasPermission(String perm) { + return true; + } +} diff --git a/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/assets/legacy-fabric-permissions-api-v1/icon.png b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/assets/legacy-fabric-permissions-api-v1/icon.png new file mode 100644 index 000000000..2931efbf6 Binary files /dev/null and b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/assets/legacy-fabric-permissions-api-v1/icon.png differ diff --git a/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/fabric.mod.json b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..7a960c2e7 --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,43 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-permissions-api-v1", + "name": "Legacy Fabric Permissions API (v2)", + "version": "${version}", + "environment": "*", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric-permissions-api-v1/icon.png", + "contact": { + "homepage": "https://legacy-fabric.github.io/", + "irc": "irc://irc.esper.net:6667/legacyfabric", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + "FabricMC" + ], + "entrypoints": { + "main": [ + "net.legacyfabric.fabric.impl.permission.PermissionImpl" + ] + }, + "depends": { + "fabricloader": ">=0.4.0", + "minecraft": "${minecraft_version}" + }, + "description": "Simple permission api", + "mixins": [ + "legacy-fabric-permissions-api-v1.mixins.json" + ], + "custom": { + "modmenu": { + "badges": [ "library" ], + "parent": { + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "badges": [ "library" ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2.", + "icon": "assets/legacy-fabric-permissions-api-v1/icon.png" + } + } + } +} diff --git a/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json new file mode 100644 index 000000000..c02686873 --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.6.4/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json @@ -0,0 +1,11 @@ +{ + "required": true, + "package": "net.legacyfabric.fabric.mixin.permission", + "compatibilityLevel": "JAVA_8", + "mixins": [ + "CommandBlockExecutorMixin" + ], + "injectors": { + "defaultRequire": 1 + } +} diff --git a/legacy-fabric-permissions-api-v1/1.8.9/gradle.properties b/legacy-fabric-permissions-api-v1/1.8.9/gradle.properties index d523a75a0..503076051 100644 --- a/legacy-fabric-permissions-api-v1/1.8.9/gradle.properties +++ b/legacy-fabric-permissions-api-v1/1.8.9/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.12.2 diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java b/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java new file mode 100644 index 000000000..a9f2f0a59 --- /dev/null +++ b/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/impl/permission/PermissionImpl.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.impl.permission; + +import net.minecraft.entity.player.ServerPlayerEntity; + +import net.fabricmc.api.ModInitializer; + +import net.legacyfabric.fabric.api.permission.v1.PermissionsApiHolder; +import net.legacyfabric.fabric.api.permission.v1.PlayerPermissionsApi; + +public class PermissionImpl implements ModInitializer { + @Override + public void onInitialize() { + PermissionsApiHolder.setFallbackPlayerPermissionsApi(FallbackPlayerPermissionsApi.INSTANCE); + } + + private enum FallbackPlayerPermissionsApi implements PlayerPermissionsApi { + INSTANCE; + + @Override + public String getId() { + return "legacy-fabric-fallback-permissions-api"; + } + + @Override + public boolean hasPermission(ServerPlayerEntity player, String perm) { + return player.server.getPlayerManager().isOperator(player.getGameProfile()); + } + } +} diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/fabric.mod.json b/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/fabric.mod.json index 919f98876..7a960c2e7 100644 --- a/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/fabric.mod.json +++ b/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/fabric.mod.json @@ -15,6 +15,11 @@ "authors": [ "FabricMC" ], + "entrypoints": { + "main": [ + "net.legacyfabric.fabric.impl.permission.PermissionImpl" + ] + }, "depends": { "fabricloader": ">=0.4.0", "minecraft": "${minecraft_version}" diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json b/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json index 8f85c2ebd..f01ad87f9 100644 --- a/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json +++ b/legacy-fabric-permissions-api-v1/1.8.9/src/main/resources/legacy-fabric-permissions-api-v1.mixins.json @@ -5,10 +5,7 @@ "mixins": [ "CommandBlockExecutorMixin", "CommandStats_1Mixin", - "ConsoleMixin", - "EntityMixin", "ExecuteCommand_1Mixin", - "ServerPlayerEntityMixin", "SignBlockEntity_1Mixin", "SignBlockEntity_2Mixin" ], diff --git a/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/api/permission/v1/PermissionsApiHolder.java b/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/api/permission/v1/PermissionsApiHolder.java index 46b3821bd..98a1cbc54 100644 --- a/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/api/permission/v1/PermissionsApiHolder.java +++ b/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/api/permission/v1/PermissionsApiHolder.java @@ -19,13 +19,6 @@ import org.jetbrains.annotations.ApiStatus; -import net.minecraft.client.MinecraftClient; -import net.minecraft.entity.player.ServerPlayerEntity; -import net.minecraft.server.MinecraftServer; - -import net.fabricmc.api.EnvType; -import net.fabricmc.loader.api.FabricLoader; - import net.legacyfabric.fabric.api.logger.v1.Logger; import net.legacyfabric.fabric.impl.logger.LoggerImpl; @@ -37,6 +30,7 @@ public class PermissionsApiHolder { private static final Logger LOGGER = Logger.get(LoggerImpl.API, "PermissionApiHolder"); private static PlayerPermissionsApi PLAYER_PERMISSIONS_API = null; + private static PlayerPermissionsApi FALLBACK_PLAYER_PERMISSIONS_API = null; public static boolean setPlayerPermissionsApi(PlayerPermissionsApi api) { if (PLAYER_PERMISSIONS_API == null) { @@ -49,32 +43,11 @@ public static boolean setPlayerPermissionsApi(PlayerPermissionsApi api) { } public static PlayerPermissionsApi getPlayerPermissionsApi() { - return PLAYER_PERMISSIONS_API != null ? PLAYER_PERMISSIONS_API : FallbackPlayerPermissionsApi.INSTANCE; + return PLAYER_PERMISSIONS_API != null ? PLAYER_PERMISSIONS_API : FALLBACK_PLAYER_PERMISSIONS_API; } - private enum FallbackPlayerPermissionsApi implements PlayerPermissionsApi { - INSTANCE; - - @Override - public String getId() { - return "legacy-fabric-fallback-permissions-api"; - } - - @Override - public boolean hasPermission(ServerPlayerEntity player, String perm) { - return getServer().getPlayerManager().isOperator(player.getGameProfile()); - } - } - - protected static MinecraftServer getServer() { - try { - return MinecraftServer.getServer(); - } catch (NoSuchMethodError e) { - if (FabricLoader.getInstance().getEnvironmentType() == EnvType.CLIENT) { - return MinecraftClient.getInstance().getServer(); - } else { - return (MinecraftServer) FabricLoader.getInstance().getGameInstance(); - } - } + @ApiStatus.Internal + public static void setFallbackPlayerPermissionsApi(PlayerPermissionsApi api) { + FALLBACK_PLAYER_PERMISSIONS_API = api; } } diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/ConsoleMixin.java b/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/ConsoleMixin.java similarity index 100% rename from legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/ConsoleMixin.java rename to legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/ConsoleMixin.java diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/EntityMixin.java b/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/EntityMixin.java similarity index 100% rename from legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/EntityMixin.java rename to legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/EntityMixin.java diff --git a/legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/ServerPlayerEntityMixin.java b/legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/ServerPlayerEntityMixin.java similarity index 100% rename from legacy-fabric-permissions-api-v1/1.8.9/src/main/java/net/legacyfabric/fabric/mixin/permission/ServerPlayerEntityMixin.java rename to legacy-fabric-permissions-api-v1/common/src/main/java/net/legacyfabric/fabric/mixin/permission/ServerPlayerEntityMixin.java diff --git a/legacy-fabric-permissions-api-v1/common/src/main/resources/fabric.mod.json b/legacy-fabric-permissions-api-v1/common/src/main/resources/fabric.mod.json index ebf36e9a6..af01052bc 100644 --- a/legacy-fabric-permissions-api-v1/common/src/main/resources/fabric.mod.json +++ b/legacy-fabric-permissions-api-v1/common/src/main/resources/fabric.mod.json @@ -20,7 +20,9 @@ "minecraft": "${minecraft_version}" }, "description": "Simple permission api", - "mixins": [], + "mixins": [ + "legacy-fabric-permissions-api-v1-common.mixins.json" + ], "custom": { "modmenu": { "badges": [ "library" ], diff --git a/legacy-fabric-permissions-api-v1/common/src/main/resources/legacy-fabric-permissions-api-v1-common.mixins.json b/legacy-fabric-permissions-api-v1/common/src/main/resources/legacy-fabric-permissions-api-v1-common.mixins.json new file mode 100644 index 000000000..a982b0f48 --- /dev/null +++ b/legacy-fabric-permissions-api-v1/common/src/main/resources/legacy-fabric-permissions-api-v1-common.mixins.json @@ -0,0 +1,13 @@ +{ + "required": true, + "package": "net.legacyfabric.fabric.mixin.permission", + "compatibilityLevel": "JAVA_8", + "mixins": [ + "ConsoleMixin", + "EntityMixin", + "ServerPlayerEntityMixin" + ], + "injectors": { + "defaultRequire": 1 + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/build.gradle b/legacy-fabric-resource-loader-v1/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacy-fabric-resource-loader-v1/1.6.4/gradle.properties b/legacy-fabric-resource-loader-v1/1.6.4/gradle.properties new file mode 100644 index 000000000..72b74abca --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.3 +maxVersionIncluded=1.6.4 diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ClientResourceReloadListenerMixins.java b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ClientResourceReloadListenerMixins.java new file mode 100644 index 000000000..4ddde0965 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ClientResourceReloadListenerMixins.java @@ -0,0 +1,94 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.resource.loader.client; + +import java.util.Collection; +import java.util.Collections; +import java.util.Locale; + +import org.spongepowered.asm.mixin.Mixin; + +import net.minecraft.client.font.TextRenderer; +import net.minecraft.client.render.GameRenderer; +import net.minecraft.client.render.WorldRenderer; +import net.minecraft.client.render.item.ItemRenderer; +import net.minecraft.client.resource.language.LanguageManager; +import net.minecraft.client.sound.SoundSystem; +import net.minecraft.client.texture.TextureManager; +import net.minecraft.resource.FoliageColorResourceReloadListener; +import net.minecraft.resource.GrassColorResourceReloadListener; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; +import net.fabricmc.loader.api.FabricLoader; +import net.fabricmc.loader.api.MappingResolver; + +import net.legacyfabric.fabric.api.resource.IdentifiableResourceReloadListener; +import net.legacyfabric.fabric.api.resource.ResourceReloadListenerKeys; +import net.legacyfabric.fabric.api.util.Identifier; + +@Mixin({ + SoundSystem.class, GameRenderer.class, LanguageManager.class, GrassColorResourceReloadListener.class, FoliageColorResourceReloadListener.class, TextureManager.class, + WorldRenderer.class, ItemRenderer.class, TextRenderer.class +}) +@Environment(EnvType.CLIENT) +public abstract class ClientResourceReloadListenerMixins implements IdentifiableResourceReloadListener { + private Collection fabric_idDeps; + private Identifier fabric_id; + + @SuppressWarnings("ConstantConditions") + @Override + public Collection getFabricDependencies() { + if (this.fabric_idDeps == null) { + Object self = this; + + if (self instanceof WorldRenderer) { + this.fabric_idDeps = Collections.singletonList(ResourceReloadListenerKeys.TEXTURES); + } else if (self instanceof ItemRenderer) { + this.fabric_idDeps = Collections.singletonList(ResourceReloadListenerKeys.MODELS); + } else { + this.fabric_idDeps = Collections.emptyList(); + } + } + + return this.fabric_idDeps; + } + + @SuppressWarnings("ConstantConditions") + @Override + public Identifier getFabricId() { + if (this.fabric_id == null) { + Object self = this; + + if (self instanceof SoundSystem) { + this.fabric_id = ResourceReloadListenerKeys.SOUNDS; + } else if (self instanceof TextRenderer) { + this.fabric_id = ResourceReloadListenerKeys.FONTS; + } else if (self instanceof LanguageManager) { + this.fabric_id = ResourceReloadListenerKeys.LANGUAGES; + } else if (self instanceof TextureManager) { + this.fabric_id = ResourceReloadListenerKeys.TEXTURES; + } else { + MappingResolver resolver = FabricLoader.getInstance().getMappingResolver(); + this.fabric_id = new Identifier("minecraft", "private/" + resolver.mapClassName("intermediary", self.getClass().getName()).toLowerCase(Locale.ROOT)); + } + } + + return this.fabric_id; + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/DefaultResourcePackMixin.java b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/DefaultResourcePackMixin.java new file mode 100644 index 000000000..4b37056fc --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/DefaultResourcePackMixin.java @@ -0,0 +1,75 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.resource.loader.client; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; +import java.util.Enumeration; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; + +import net.minecraft.resource.DefaultResourcePack; +import net.minecraft.util.Identifier; + +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; + +@Environment(EnvType.CLIENT) +@Mixin(DefaultResourcePack.class) +public class DefaultResourcePackMixin { + @Inject(method = "openClassLoader", at = @At("HEAD"), cancellable = true) + protected void onFindInputStream(Identifier identifier, CallbackInfoReturnable callback) { + // if (DefaultResourcePack.resourcePath != null) { + // Fall through to Vanilla logic, they have a special case here. + // return; + // } + + String path = "assets/" + identifier.getNamespace() + "/" + identifier.getPath(); + URL found = null; + + try { + Enumeration candidates = DefaultResourcePack.class.getClassLoader().getResources(path); + + // Get the last element + while (candidates.hasMoreElements()) { + found = candidates.nextElement(); + } + + if (found == null) { + // Mimics vanilla behavior + + callback.setReturnValue(null); + return; + } + } catch (IOException var6) { + // Default path + } + + try { + if (found != null) { + callback.setReturnValue(found.openStream()); + } + } catch (Exception e) { + // Default path + } + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/MinecraftClientMixin.java b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/MinecraftClientMixin.java new file mode 100644 index 000000000..c05d9ccc2 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/MinecraftClientMixin.java @@ -0,0 +1,70 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.resource.loader.client; + +import java.util.ArrayList; +import java.util.List; + +import com.google.common.collect.Lists; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +import net.minecraft.client.MinecraftClient; +import net.minecraft.resource.DefaultResourcePack; +import net.minecraft.resource.ResourcePack; + +import net.legacyfabric.fabric.impl.resource.loader.ModResourcePackUtil; + +@Mixin(MinecraftClient.class) +public class MinecraftClientMixin { + private void fabric_modifyResourcePackList(List list) { + List oldList = Lists.newArrayList(list); + list.clear(); + + boolean appended = false; + + for (ResourcePack pack : oldList) { + list.add(pack); + + boolean isDefaultResources = pack instanceof DefaultResourcePack; + + if (isDefaultResources) { + ModResourcePackUtil.appendModResourcePacks(list); + appended = true; + } + } + + if (!appended) { + StringBuilder builder = new StringBuilder("Fabric could not find resource pack injection location!"); + + for (ResourcePack rp : oldList) { + builder.append("\n - ").append(rp.getName()).append(" (").append(rp.getClass().getName()).append(")"); + } + + throw new RuntimeException(builder.toString()); + } + } + + @Inject(method = "reloadResources", at = @At(value = "INVOKE", target = "Lnet/minecraft/resource/ReloadableResourceManager;reload(Ljava/util/List;)V", ordinal = 0), locals = LocalCapture.CAPTURE_FAILHARD) + public void reloadResources(CallbackInfo ci, ArrayList list) { + fabric_modifyResourcePackList(list); + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ReloadableResourceManagerImplMixin.java b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ReloadableResourceManagerImplMixin.java new file mode 100644 index 000000000..5a88eb98a --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/ReloadableResourceManagerImplMixin.java @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.mixin.resource.loader.client; + +import java.util.List; + +import org.spongepowered.asm.mixin.Final; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import net.minecraft.resource.ReloadableResourceManagerImpl; +import net.minecraft.resource.ResourcePack; +import net.minecraft.resource.ResourceReloadListener; + +import net.legacyfabric.fabric.impl.resource.loader.ResourceManagerHelperImpl; + +@Mixin(ReloadableResourceManagerImpl.class) +public class ReloadableResourceManagerImplMixin { + @Shadow + @Final + private List listeners; + + @Inject(method = "reload", at = @At(value = "INVOKE", target = "Lnet/minecraft/util/logging/LogManager;info(Ljava/lang/String;)V")) + public void onReload(List resourcePacks, CallbackInfo ci) { + ResourceManagerHelperImpl.getInstance().sort(this.listeners); + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png new file mode 100644 index 000000000..2931efbf6 Binary files /dev/null and b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/assets/legacy-fabric/icon.png differ diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/fabric.mod.json b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..f70352482 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,38 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-resource-loader-v1", + "name": "Legacy Fabric Resource Loader (V1)", + "version": "${version}", + "environment": "*", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric/icon.png", + "contact": { + "homepage": "https://legacyfabric.net/", + "irc": "irc://irc.esper.net:6667/legacyfabric", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + "FabricMC" + ], + "depends": { + "fabricloader": ">=0.4.0", + "minecraft": "${minecraft_version}" + }, + "description": "Asset loading", + "mixins": [ + "legacy-fabric-resource-loader-v1.mixins.json" + ], + "custom": { + "modmenu": { + "badges": [ "library" ], + "parent": { + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "badges": [ "library" ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2.", + "icon": "assets/legacy-fabric/icon.png" + } + } + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/legacy-fabric-resource-loader-v1.mixins.json b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/legacy-fabric-resource-loader-v1.mixins.json new file mode 100644 index 000000000..7b3aa4675 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/main/resources/legacy-fabric-resource-loader-v1.mixins.json @@ -0,0 +1,14 @@ +{ + "required": true, + "package": "net.legacyfabric.fabric.mixin.resource.loader", + "compatibilityLevel": "JAVA_8", + "client": [ + "client.ClientResourceReloadListenerMixins", + "client.DefaultResourcePackMixin", + "client.MinecraftClientMixin", + "client.ReloadableResourceManagerImplMixin" + ], + "injectors": { + "defaultRequire": 1 + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/resource/loader/client/ResourceReloadTest.java b/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/resource/loader/client/ResourceReloadTest.java new file mode 100644 index 000000000..99ab573c7 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/java/net/legacyfabric/fabric/test/resource/loader/client/ResourceReloadTest.java @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2020 - 2024 Legacy Fabric + * Copyright (c) 2016 - 2022 FabricMC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.legacyfabric.fabric.test.resource.loader.client; + +import java.util.Arrays; + +import net.minecraft.resource.ResourceManager; + +import net.fabricmc.api.ClientModInitializer; + +import net.legacyfabric.fabric.api.logger.v1.Logger; +import net.legacyfabric.fabric.api.resource.IdentifiableResourceReloadListener; +import net.legacyfabric.fabric.api.resource.ResourceManagerHelper; +import net.legacyfabric.fabric.api.util.Identifier; +import net.legacyfabric.fabric.impl.logger.LoggerImpl; + +public class ResourceReloadTest implements ClientModInitializer { + private static final Logger LOGGER = Logger.get(LoggerImpl.API, "Test", "ResourceReload"); + + @Override + public void onInitializeClient() { + Identifier id = new Identifier("legacy-fabric-api", "test_reload"); + ResourceManagerHelper.getInstance().registerReloadListener(new IdentifiableResourceReloadListener() { + @Override + public Identifier getFabricId() { + return id; + } + + @Override + public void reload(ResourceManager resourceManager) { + LOGGER.info("Resources and reloading"); + LOGGER.info("Namespaces are %s", Arrays.toString(resourceManager.getAllNamespaces().toArray())); + } + }); + } +} diff --git a/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/resources/fabric.mod.json b/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/resources/fabric.mod.json new file mode 100644 index 000000000..5f42c7640 --- /dev/null +++ b/legacy-fabric-resource-loader-v1/1.6.4/src/testmod/resources/fabric.mod.json @@ -0,0 +1,14 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-resource-loader-v1-testmod", + "description": "Tests for resource loading", + "version": "1.0.0", + "entrypoints": { + "client": [ + "net.legacyfabric.fabric.test.resource.loader.client.ResourceReloadTest" + ] + }, + "depends": { + "minecraft": "${minecraft_version}" + } +} diff --git a/legacy-fabric-resource-loader-v1/1.7.10/gradle.properties b/legacy-fabric-resource-loader-v1/1.7.10/gradle.properties index c6dcd9541..af031afbf 100644 --- a/legacy-fabric-resource-loader-v1/1.7.10/gradle.properties +++ b/legacy-fabric-resource-loader-v1/1.7.10/gradle.properties @@ -1,2 +1,2 @@ -minVersionIncluded=1.3 +minVersionIncluded=1.7.10 maxVersionIncluded=1.7.10 diff --git a/legacy-fabric-resource-loader-v1/common/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/TranslationStorageMixin.java b/legacy-fabric-resource-loader-v1/common/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/TranslationStorageMixin.java index 33682ac59..632aeff0e 100644 --- a/legacy-fabric-resource-loader-v1/common/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/TranslationStorageMixin.java +++ b/legacy-fabric-resource-loader-v1/common/src/main/java/net/legacyfabric/fabric/mixin/resource/loader/client/TranslationStorageMixin.java @@ -19,7 +19,6 @@ import java.io.IOException; import java.io.InputStream; -import java.io.StringReader; import java.util.List; import java.util.Locale; import java.util.Map; @@ -27,10 +26,9 @@ import com.google.common.base.Splitter; import com.google.common.collect.Iterables; -import com.google.gson.Gson; -import com.google.gson.GsonBuilder; import com.google.gson.JsonElement; import com.google.gson.JsonObject; +import com.google.gson.JsonParser; import org.apache.commons.io.Charsets; import org.apache.commons.io.IOUtils; import org.jetbrains.annotations.NotNull; @@ -38,6 +36,7 @@ import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Overwrite; import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.Unique; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; @@ -63,9 +62,11 @@ public abstract class TranslationStorageMixin { @Shadow Map translations; + @Unique private static final boolean isUpperCase = VersionUtils.matches("<1.11"); - private static final Gson GSON = new GsonBuilder().create(); + @Unique + private static final JsonParser JSON_PARSER = new JsonParser(); @Inject(method = "load(Lnet/minecraft/resource/ResourceManager;Ljava/util/List;)V", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/resource/language/TranslationStorage;setRightToLeft()V")) private void loadLangFileFromOtherVersion(ResourceManager resourceManager, List languages, CallbackInfo ci) { @@ -115,8 +116,7 @@ private void load(InputStream stream) throws IOException { if (lines.get(0).startsWith("{")) { // Load as json String content = String.join("\n", lines); - JsonObject object = GSON.fromJson(new StringReader(content), JsonObject.class); - + JsonObject object = JSON_PARSER.parse(content).getAsJsonObject(); recursiveLoadTranslations("", object); } else { // Load as properties/lang for (String string : lines) { diff --git a/legacyfabric-api/1.6.4/build.gradle b/legacyfabric-api/1.6.4/build.gradle new file mode 100644 index 000000000..e69de29bb diff --git a/legacyfabric-api/1.6.4/gradle.properties b/legacyfabric-api/1.6.4/gradle.properties new file mode 100644 index 000000000..bff6c84c0 --- /dev/null +++ b/legacyfabric-api/1.6.4/gradle.properties @@ -0,0 +1,2 @@ +minVersionIncluded=1.6.4 +maxVersionIncluded=1.6.4 diff --git a/legacyfabric-api/1.6.4/src/main/resources/fabric.mod.json b/legacyfabric-api/1.6.4/src/main/resources/fabric.mod.json new file mode 100644 index 000000000..95213e984 --- /dev/null +++ b/legacyfabric-api/1.6.4/src/main/resources/fabric.mod.json @@ -0,0 +1,43 @@ +{ + "schemaVersion": 1, + "id": "legacy-fabric-api", + "name": "Legacy Fabric API", + "version": "${version}", + "environment": "*", + "license": "Apache-2.0", + "icon": "assets/legacy-fabric-api/icon.png", + "contact": { + "homepage": "https://legacyfabric.net/", + "issues": "https://github.com/Legacy-Fabric/fabric/issues", + "sources": "https://github.com/Legacy-Fabric/fabric" + }, + "authors": [ + { + "name": "Legacy Fabric", + "contact": { + "homepage": "https://legacyfabric.net/", + "discord": "https://legacyfabric.net/discord", + "sources": "https://github.com/Legacy-Fabric/fabric", + "issues": "https://github.com/Legacy-Fabric/fabric/issues" + } + }, + { + "name": "FabricMC", + "contact": { + "homepage": "https://fabricmc.net", + "discord": "https://discord.gg/v6v4pMv", + "sources": "https://github.com/FabricMC/fabric", + "issues": "https://github.com/FabricMC/fabric/issues" + } + } + ], + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.6.4-1.12.2.", + "depends": { + "minecraft": "${minecraft_version}" + }, + "custom": { + "modmenu": { + "badges": [ "library" ] + } + } +} diff --git a/src/main/resources/fabric.mod.json b/src/main/resources/fabric.mod.json index 74afb3a70..5190561ab 100644 --- a/src/main/resources/fabric.mod.json +++ b/src/main/resources/fabric.mod.json @@ -31,5 +31,5 @@ } } ], - "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.7.10-1.12.2." + "description": "Core API module providing key hooks and inter-compatibility features for Minecraft 1.6.4-1.12.2." }