Initial
This commit is contained in:
commit
b2c3a14efe
14 changed files with 603 additions and 0 deletions
119
.gitignore
vendored
Normal file
119
.gitignore
vendored
Normal file
|
@ -0,0 +1,119 @@
|
|||
# User-specific stuff
|
||||
.idea/
|
||||
|
||||
*.iml
|
||||
*.ipr
|
||||
*.iws
|
||||
|
||||
# IntelliJ
|
||||
out/
|
||||
# mpeltonen/sbt-idea plugin
|
||||
.idea_modules/
|
||||
|
||||
# JIRA plugin
|
||||
atlassian-ide-plugin.xml
|
||||
|
||||
# Compiled class file
|
||||
*.class
|
||||
|
||||
# Log file
|
||||
*.log
|
||||
|
||||
# BlueJ files
|
||||
*.ctxt
|
||||
|
||||
# Package Files #
|
||||
*.jar
|
||||
*.war
|
||||
*.nar
|
||||
*.ear
|
||||
*.zip
|
||||
*.tar.gz
|
||||
*.rar
|
||||
|
||||
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
|
||||
hs_err_pid*
|
||||
|
||||
*~
|
||||
|
||||
# temporary files which can be created if a process still has a handle open of a deleted file
|
||||
.fuse_hidden*
|
||||
|
||||
# KDE directory preferences
|
||||
.directory
|
||||
|
||||
# Linux trash folder which might appear on any partition or disk
|
||||
.Trash-*
|
||||
|
||||
# .nfs files are created when an open file is removed but is still being accessed
|
||||
.nfs*
|
||||
|
||||
# General
|
||||
.DS_Store
|
||||
.AppleDouble
|
||||
.LSOverride
|
||||
|
||||
# Icon must end with two \r
|
||||
Icon
|
||||
|
||||
# Thumbnails
|
||||
._*
|
||||
|
||||
# Files that might appear in the root of a volume
|
||||
.DocumentRevisions-V100
|
||||
.fseventsd
|
||||
.Spotlight-V100
|
||||
.TemporaryItems
|
||||
.Trashes
|
||||
.VolumeIcon.icns
|
||||
.com.apple.timemachine.donotpresent
|
||||
|
||||
# Directories potentially created on remote AFP share
|
||||
.AppleDB
|
||||
.AppleDesktop
|
||||
Network Trash Folder
|
||||
Temporary Items
|
||||
.apdisk
|
||||
|
||||
# Windows thumbnail cache files
|
||||
Thumbs.db
|
||||
Thumbs.db:encryptable
|
||||
ehthumbs.db
|
||||
ehthumbs_vista.db
|
||||
|
||||
# Dump file
|
||||
*.stackdump
|
||||
|
||||
# Folder config file
|
||||
[Dd]esktop.ini
|
||||
|
||||
# Recycle Bin used on file shares
|
||||
$RECYCLE.BIN/
|
||||
|
||||
# Windows Installer files
|
||||
*.cab
|
||||
*.msi
|
||||
*.msix
|
||||
*.msm
|
||||
*.msp
|
||||
|
||||
# Windows shortcuts
|
||||
*.lnk
|
||||
|
||||
.gradle
|
||||
build/
|
||||
|
||||
# Ignore Gradle GUI config
|
||||
gradle-app.setting
|
||||
|
||||
# Cache of project
|
||||
.gradletasknamecache
|
||||
|
||||
**/build/
|
||||
|
||||
# Common working directory
|
||||
run/
|
||||
runs/
|
||||
|
||||
# Avoid ignoring Gradle wrapper jar file (.jar files are usually ignored)
|
||||
!gradle-wrapper.jar
|
21
LICENSE.txt
Normal file
21
LICENSE.txt
Normal file
|
@ -0,0 +1,21 @@
|
|||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2024 Alessandro "AlexDevs" Proto
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
95
build.gradle
Normal file
95
build.gradle
Normal file
|
@ -0,0 +1,95 @@
|
|||
plugins {
|
||||
id 'fabric-loom' version '1.8-SNAPSHOT'
|
||||
id 'maven-publish'
|
||||
}
|
||||
|
||||
version = project.mod_version
|
||||
group = project.maven_group
|
||||
|
||||
base {
|
||||
archivesName = project.archives_base_name
|
||||
}
|
||||
|
||||
|
||||
repositories {
|
||||
// Add repositories to retrieve artifacts from in here.
|
||||
// You should only use this when depending on other mods because
|
||||
// Loom adds the essential maven repositories to download Minecraft and libraries from automatically.
|
||||
// See https://docs.gradle.org/current/userguide/declaring_repositories.html
|
||||
// for more information about repositories.
|
||||
maven {
|
||||
name = "EngineHub"
|
||||
url = "https://maven.enginehub.org/repo/"
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
// To change the versions see the gradle.properties file
|
||||
minecraft "com.mojang:minecraft:${project.minecraft_version}"
|
||||
mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2"
|
||||
modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
|
||||
|
||||
modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}"
|
||||
|
||||
modImplementation "com.sk89q.worldedit:worldedit-fabric-mc1.20:7.3.0-SNAPSHOT"
|
||||
}
|
||||
|
||||
processResources {
|
||||
inputs.property "version", project.version
|
||||
inputs.property "minecraft_version", project.minecraft_version
|
||||
inputs.property "loader_version", project.loader_version
|
||||
filteringCharset "UTF-8"
|
||||
|
||||
filesMatching("fabric.mod.json") {
|
||||
expand "version": project.version,
|
||||
"minecraft_version": project.minecraft_version,
|
||||
"loader_version": project.loader_version
|
||||
}
|
||||
}
|
||||
|
||||
def targetJavaVersion = 17
|
||||
tasks.withType(JavaCompile).configureEach {
|
||||
// ensure that the encoding is set to UTF-8, no matter what the system default is
|
||||
// this fixes some edge cases with special characters not displaying correctly
|
||||
// see http://yodaconditions.net/blog/fix-for-java-file-encoding-problems-with-gradle.html
|
||||
// If Javadoc is generated, this must be specified in that task too.
|
||||
it.options.encoding = "UTF-8"
|
||||
if (targetJavaVersion >= 10 || JavaVersion.current().isJava10Compatible()) {
|
||||
it.options.release.set(targetJavaVersion)
|
||||
}
|
||||
}
|
||||
|
||||
java {
|
||||
def javaVersion = JavaVersion.toVersion(targetJavaVersion)
|
||||
if (JavaVersion.current() < javaVersion) {
|
||||
toolchain.languageVersion = JavaLanguageVersion.of(targetJavaVersion)
|
||||
}
|
||||
// Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task
|
||||
// if it is present.
|
||||
// If you remove this line, sources will not be generated.
|
||||
withSourcesJar()
|
||||
}
|
||||
|
||||
jar {
|
||||
from("LICENSE") {
|
||||
rename { "${it}_${project.archivesBaseName}" }
|
||||
}
|
||||
}
|
||||
|
||||
// configure the maven publication
|
||||
publishing {
|
||||
publications {
|
||||
create("mavenJava", MavenPublication) {
|
||||
artifactId = project.archives_base_name
|
||||
from components.java
|
||||
}
|
||||
}
|
||||
|
||||
// See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing.
|
||||
repositories {
|
||||
// Add repositories to publish to here.
|
||||
// Notice: This block does NOT have the same function as the block in the top level.
|
||||
// The repositories here will be used for publishing your artifact, not for
|
||||
// retrieving dependencies.
|
||||
}
|
||||
}
|
15
gradle.properties
Normal file
15
gradle.properties
Normal file
|
@ -0,0 +1,15 @@
|
|||
# Done to increase the memory available to gradle.
|
||||
org.gradle.jvmargs=-Xmx1G
|
||||
# Fabric Properties
|
||||
# check these on https://modmuss50.me/fabric.html
|
||||
minecraft_version=1.20.1
|
||||
yarn_mappings=1.20.1+build.10
|
||||
loader_version=0.16.9
|
||||
# Mod Properties
|
||||
mod_version=1.0-SNAPSHOT
|
||||
maven_group=me.alexdevs
|
||||
archives_base_name=claimcore
|
||||
# Dependencies
|
||||
# check this on https://modmuss50.me/fabric.html
|
||||
fabric_version=0.92.2+1.20.1
|
||||
worldeditapi_version=
|
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.10.2-bin.zip
|
9
settings.gradle
Normal file
9
settings.gradle
Normal file
|
@ -0,0 +1,9 @@
|
|||
pluginManagement {
|
||||
repositories {
|
||||
maven {
|
||||
name = 'Fabric'
|
||||
url = 'https://maven.fabricmc.net/'
|
||||
}
|
||||
gradlePluginPortal()
|
||||
}
|
||||
}
|
55
src/main/java/me/alexdevs/claimcore/ClaimCore.java
Normal file
55
src/main/java/me/alexdevs/claimcore/ClaimCore.java
Normal file
|
@ -0,0 +1,55 @@
|
|||
package me.alexdevs.claimcore;
|
||||
|
||||
import com.sk89q.worldedit.WorldEdit;
|
||||
import com.sk89q.worldedit.fabric.FabricAdapter;
|
||||
import com.sk89q.worldedit.internal.cui.CUIEvent;
|
||||
import com.sk89q.worldedit.session.SessionOwner;
|
||||
import me.alexdevs.claimcore.core.ClaimManager;
|
||||
import me.alexdevs.claimcore.core.InteractionManager;
|
||||
import net.fabricmc.api.ModInitializer;
|
||||
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerLifecycleEvents;
|
||||
import net.fabricmc.fabric.api.event.player.PlayerBlockBreakEvents;
|
||||
import net.fabricmc.fabric.api.event.player.UseBlockCallback;
|
||||
import net.fabricmc.fabric.api.event.player.UseItemCallback;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.registry.RegistryKeys;
|
||||
import net.minecraft.server.MinecraftServer;
|
||||
import net.minecraft.text.Text;
|
||||
import net.minecraft.util.ActionResult;
|
||||
import net.minecraft.util.Hand;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.util.TypedActionResult;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
public class ClaimCore implements ModInitializer {
|
||||
public static final String MOD_ID = "claimcore";
|
||||
public static final Logger LOGGER = LoggerFactory.getLogger(ClaimCore.class);
|
||||
public static String claimToolName = "minecraft:golden_shovel";
|
||||
public static Item claimTool;
|
||||
public static String virtualBlockName = "minecraft:gold_block";
|
||||
public static Block virtualBlock;
|
||||
|
||||
public static MinecraftServer server;
|
||||
|
||||
public static InteractionManager interactionManager;
|
||||
public static final ClaimManager claimManager = new ClaimManager();
|
||||
|
||||
@Override
|
||||
public void onInitialize() {
|
||||
LOGGER.info("Initializing ClaimCore");
|
||||
|
||||
interactionManager = new InteractionManager();
|
||||
|
||||
ServerLifecycleEvents.SERVER_STARTING.register((server) -> {
|
||||
ClaimCore.server = server;
|
||||
claimTool = server.getRegistryManager().get(RegistryKeys.ITEM).get(Identifier.tryParse(claimToolName));
|
||||
virtualBlock = server.getRegistryManager().get(RegistryKeys.BLOCK).get(Identifier.tryParse(virtualBlockName));
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package me.alexdevs.claimcore.api.event;
|
||||
|
||||
import net.fabricmc.fabric.api.event.Event;
|
||||
import net.fabricmc.fabric.api.event.EventFactory;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
|
||||
public interface PlayerEquipmentChange {
|
||||
Event<PlayerEquipmentChange> EVENT = EventFactory.createArrayBacked(PlayerEquipmentChange.class, listeners -> (player) -> {
|
||||
for (PlayerEquipmentChange listener : listeners) {
|
||||
listener.changeEquipment(player);
|
||||
}
|
||||
});
|
||||
|
||||
void changeEquipment(PlayerEntity player);
|
||||
}
|
66
src/main/java/me/alexdevs/claimcore/core/Claim.java
Normal file
66
src/main/java/me/alexdevs/claimcore/core/Claim.java
Normal file
|
@ -0,0 +1,66 @@
|
|||
package me.alexdevs.claimcore.core;
|
||||
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
public class Claim {
|
||||
public enum ClaimType {
|
||||
FLAT,
|
||||
CUBIC,
|
||||
}
|
||||
|
||||
public UUID owner;
|
||||
public final BlockPos pos1;
|
||||
public final BlockPos pos2;
|
||||
public ClaimType type;
|
||||
public World world;
|
||||
public final Volume volume;
|
||||
|
||||
public Claim(UUID owner, BlockPos pos1, BlockPos pos2, World world, ClaimType type) {
|
||||
this.owner = owner;
|
||||
this.pos1 = pos1;
|
||||
this.pos2 = pos2;
|
||||
this.world = world;
|
||||
this.type = type;
|
||||
volume = new Volume(pos1, pos2);
|
||||
}
|
||||
|
||||
public static Claim createFlatClaim(UUID owner, BlockPos pos1, BlockPos pos2, World world) {
|
||||
// The engine says 2,032 in both +Y and -Y is the max possible value.
|
||||
pos1 = new BlockPos(pos1.getX(), -2048, pos1.getZ());
|
||||
pos2 = new BlockPos(pos2.getX(), +2048, pos2.getZ());
|
||||
return new Claim(owner, pos1, pos2, world, ClaimType.FLAT);
|
||||
}
|
||||
|
||||
public static Claim createCubicClaim(UUID owner, BlockPos pos1, BlockPos pos2, World world) {
|
||||
return new Claim(owner, pos1, pos2, world, ClaimType.CUBIC);
|
||||
}
|
||||
|
||||
public static class Volume {
|
||||
public final int minX, minY, minZ;
|
||||
public final int maxX, maxY, maxZ;
|
||||
|
||||
public Volume(BlockPos pos1, BlockPos pos2) {
|
||||
this.minX = Math.min(pos1.getX(), pos2.getX());
|
||||
this.maxX = Math.max(pos1.getX(), pos2.getX());
|
||||
this.minY = Math.min(pos1.getY(), pos2.getY());
|
||||
this.maxY = Math.max(pos1.getY(), pos2.getY());
|
||||
this.minZ = Math.min(pos1.getZ(), pos2.getZ());
|
||||
this.maxZ = Math.max(pos1.getZ(), pos2.getZ());
|
||||
}
|
||||
|
||||
public boolean contains(BlockPos target) {
|
||||
return target.getX() >= minX && target.getX() <= maxX &&
|
||||
target.getY() >= minY && target.getY() <= maxY &&
|
||||
target.getZ() >= minZ && target.getZ() <= maxZ;
|
||||
}
|
||||
|
||||
public boolean intersects(Volume other) {
|
||||
return (this.maxX >= other.minX && other.maxX >= this.minX)
|
||||
&& (this.maxY >= other.minY && other.maxY >= this.minY)
|
||||
&& (this.maxZ >= other.minZ && other.maxZ >= this.minZ);
|
||||
}
|
||||
}
|
||||
}
|
29
src/main/java/me/alexdevs/claimcore/core/ClaimManager.java
Normal file
29
src/main/java/me/alexdevs/claimcore/core/ClaimManager.java
Normal file
|
@ -0,0 +1,29 @@
|
|||
package me.alexdevs.claimcore.core;
|
||||
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
public class ClaimManager {
|
||||
public final ArrayList<Claim> claims = new ArrayList<>();
|
||||
|
||||
|
||||
public ClaimManager() {
|
||||
|
||||
}
|
||||
|
||||
public void createClaim(Claim claim) {
|
||||
claims.add(claim);
|
||||
}
|
||||
|
||||
@Nullable
|
||||
public Claim getClaimAtPosition(World world, BlockPos pos) {
|
||||
for (Claim claim : claims) {
|
||||
if(claim.volume.contains(pos))
|
||||
return claim;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
116
src/main/java/me/alexdevs/claimcore/core/InteractionManager.java
Normal file
116
src/main/java/me/alexdevs/claimcore/core/InteractionManager.java
Normal file
|
@ -0,0 +1,116 @@
|
|||
package me.alexdevs.claimcore.core;
|
||||
|
||||
import com.sk89q.worldedit.WorldEdit;
|
||||
import com.sk89q.worldedit.fabric.FabricAdapter;
|
||||
import com.sk89q.worldedit.internal.cui.SelectionPointEvent;
|
||||
import me.alexdevs.claimcore.ClaimCore;
|
||||
import me.alexdevs.claimcore.api.event.PlayerEquipmentChange;
|
||||
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerTickEvents;
|
||||
import net.fabricmc.fabric.api.event.player.AttackBlockCallback;
|
||||
import net.fabricmc.fabric.api.event.player.PlayerBlockBreakEvents;
|
||||
import net.fabricmc.fabric.api.event.player.UseBlockCallback;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.network.packet.s2c.play.BlockUpdateS2CPacket;
|
||||
import net.minecraft.server.network.ServerPlayerEntity;
|
||||
import net.minecraft.server.world.ServerWorld;
|
||||
import net.minecraft.text.Text;
|
||||
import net.minecraft.util.ActionResult;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
public class InteractionManager {
|
||||
private final HashMap<UUID, BlockPos> areaSelections = new HashMap<>();
|
||||
private final Queue<FakeBlock> fakeBlockQueue = new LinkedList<>();
|
||||
|
||||
public InteractionManager() {
|
||||
|
||||
UseBlockCallback.EVENT.register((playerEntity, world, hand, hitResult) -> {
|
||||
var currentItem = playerEntity.getStackInHand(hand).getItem();
|
||||
if(!currentItem.equals(ClaimCore.claimTool)) {
|
||||
return ActionResult.PASS;
|
||||
}
|
||||
|
||||
var playerUuid = playerEntity.getUuid();
|
||||
var player = ClaimCore.server.getPlayerManager().getPlayer(playerUuid);
|
||||
assert player != null;
|
||||
|
||||
var blockPos = hitResult.getBlockPos();
|
||||
var playerWE = FabricAdapter.adaptPlayer(player);
|
||||
var blockVector = FabricAdapter.adapt(blockPos);
|
||||
var session = WorldEdit.getInstance().getSessionManager().get(playerWE);
|
||||
if(areaSelections.containsKey(playerUuid)) {
|
||||
session.dispatchCUIEvent(playerWE, new SelectionPointEvent(
|
||||
1, blockVector, 100L
|
||||
));
|
||||
tryClaim(player, player.getServerWorld(), areaSelections.get(playerUuid), blockPos);
|
||||
areaSelections.remove(playerUuid);
|
||||
return ActionResult.FAIL;
|
||||
}
|
||||
|
||||
areaSelections.put(playerUuid, blockPos);
|
||||
player.sendMessage(
|
||||
Text.of("Selected first position: " + blockPos.toShortString())
|
||||
);
|
||||
|
||||
session.dispatchCUIEvent(playerWE, new SelectionPointEvent(
|
||||
0, blockVector, 1L
|
||||
));
|
||||
|
||||
return ActionResult.FAIL;
|
||||
});
|
||||
|
||||
PlayerEquipmentChange.EVENT.register(player -> {
|
||||
if(!player.getMainHandStack().getItem().equals(ClaimCore.claimTool)) {
|
||||
areaSelections.remove(player.getUuid());
|
||||
}
|
||||
});
|
||||
|
||||
ServerTickEvents.END_SERVER_TICK.register(server -> {
|
||||
while(!fakeBlockQueue.isEmpty()) {
|
||||
var fakeBlock = fakeBlockQueue.poll();
|
||||
fakeBlock.player.networkHandler.sendPacket(new BlockUpdateS2CPacket(
|
||||
fakeBlock.pos,
|
||||
fakeBlock.block.getDefaultState()
|
||||
));
|
||||
}
|
||||
});
|
||||
|
||||
AttackBlockCallback.EVENT.register((player, world, hand, pos, direction) -> {
|
||||
var claim = ClaimCore.claimManager.getClaimAtPosition(world, pos);
|
||||
if(claim == null) {
|
||||
return ActionResult.PASS;
|
||||
}
|
||||
|
||||
player.sendMessage(Text.of("You cannot grief this mf"));
|
||||
return ActionResult.FAIL;
|
||||
});
|
||||
|
||||
|
||||
PlayerBlockBreakEvents.BEFORE.register((world, player, pos, state, blockEntity) -> {
|
||||
var claim = ClaimCore.claimManager.getClaimAtPosition(world, pos);
|
||||
return claim == null;
|
||||
});
|
||||
}
|
||||
|
||||
public void tryClaim(PlayerEntity player, ServerWorld world, BlockPos pos1, BlockPos pos2) {
|
||||
var volume = new Claim.Volume(pos1, pos2);
|
||||
for(var claim : ClaimCore.claimManager.claims) {
|
||||
if(claim.volume.intersects(volume)) {
|
||||
player.sendMessage(Text.of("Intersects with existing claim!"));
|
||||
return;
|
||||
}
|
||||
}
|
||||
ClaimCore.claimManager.createClaim(Claim.createFlatClaim(
|
||||
player.getUuid(),
|
||||
pos1,
|
||||
pos2,
|
||||
world
|
||||
));
|
||||
|
||||
player.sendMessage(Text.of("Created claim!"));
|
||||
}
|
||||
|
||||
public record FakeBlock(ServerPlayerEntity player, BlockPos pos, Block block) {}
|
||||
}
|
|
@ -0,0 +1,23 @@
|
|||
package me.alexdevs.claimcore.mixin;
|
||||
|
||||
import me.alexdevs.claimcore.api.event.PlayerEquipmentChange;
|
||||
import net.minecraft.entity.EquipmentSlot;
|
||||
import net.minecraft.entity.LivingEntity;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.item.ItemStack;
|
||||
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 java.util.Map;
|
||||
|
||||
@Mixin(LivingEntity.class)
|
||||
public class EquipmentChangesMixin {
|
||||
@Inject(method = "getEquipmentChanges", at = @At(target = "Ljava/util/Map;put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;", value = "INVOKE"))
|
||||
private void claimCore$getEquipmentChanges(CallbackInfoReturnable<Map<EquipmentSlot, ItemStack>> cir) {
|
||||
if((Object)this instanceof PlayerEntity player) {
|
||||
PlayerEquipmentChange.EVENT.invoker().changeEquipment(player);
|
||||
}
|
||||
}
|
||||
}
|
14
src/main/resources/claimcore.mixins.json
Normal file
14
src/main/resources/claimcore.mixins.json
Normal file
|
@ -0,0 +1,14 @@
|
|||
{
|
||||
"required": true,
|
||||
"minVersion": "0.8",
|
||||
"package": "me.alexdevs.claimcore.mixin",
|
||||
"compatibilityLevel": "JAVA_17",
|
||||
"mixins": [
|
||||
"EquipmentChangesMixin"
|
||||
],
|
||||
"client": [
|
||||
],
|
||||
"injectors": {
|
||||
"defaultRequire": 1
|
||||
}
|
||||
}
|
25
src/main/resources/fabric.mod.json
Normal file
25
src/main/resources/fabric.mod.json
Normal file
|
@ -0,0 +1,25 @@
|
|||
{
|
||||
"schemaVersion": 1,
|
||||
"id": "claimcore",
|
||||
"version": "${version}",
|
||||
"name": "ClaimCore",
|
||||
"description": "Fabric mod to protect player structures",
|
||||
"authors": [],
|
||||
"contact": {},
|
||||
"license": "MIT",
|
||||
"icon": "assets/claimcore/icon.png",
|
||||
"environment": "server",
|
||||
"entrypoints": {
|
||||
"main": [
|
||||
"me.alexdevs.claimcore.ClaimCore"
|
||||
]
|
||||
},
|
||||
"mixins": [
|
||||
"claimcore.mixins.json"
|
||||
],
|
||||
"depends": {
|
||||
"fabricloader": ">=${loader_version}",
|
||||
"fabric": "*",
|
||||
"minecraft": "${minecraft_version}"
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue