Compare commits
8 commits
1cc787230c
...
225adf0354
Author | SHA1 | Date | |
---|---|---|---|
225adf0354 | |||
812b16e4be | |||
1acfcd273d | |||
c92d4429da | |||
6153da89a1 | |||
3a6d1366ab | |||
9e4125dd4e | |||
69cb2ef9af |
13 changed files with 77 additions and 48 deletions
src/main
|
@ -59,7 +59,7 @@ public record TweaksConfig(
|
||||||
|
|
||||||
Map<String, Object> knockbackModifiers
|
Map<String, Object> knockbackModifiers
|
||||||
) {
|
) {
|
||||||
public static final int CONFIG_VERSION = 1;
|
public static final int CONFIG_VERSION = 2;
|
||||||
private static TweaksConfig config;
|
private static TweaksConfig config;
|
||||||
|
|
||||||
public static TweaksConfig getConfig() {
|
public static TweaksConfig getConfig() {
|
||||||
|
@ -72,11 +72,12 @@ public record TweaksConfig(
|
||||||
|
|
||||||
int configVersion = config.getInt("magic number don't modify this", 0);
|
int configVersion = config.getInt("magic number don't modify this", 0);
|
||||||
RuntimeException exception = new RuntimeException("Config version is %d, expected %d".formatted(configVersion, CONFIG_VERSION));
|
RuntimeException exception = new RuntimeException("Config version is %d, expected %d".formatted(configVersion, CONFIG_VERSION));
|
||||||
|
|
||||||
if (configVersion == 0) {
|
if (configVersion == 0) {
|
||||||
throw exception;
|
throw exception;
|
||||||
} else if (configVersion > CONFIG_VERSION) {
|
|
||||||
throw new RuntimeException("Please follow update instructions", exception);
|
|
||||||
} else if (configVersion < CONFIG_VERSION) {
|
} else if (configVersion < CONFIG_VERSION) {
|
||||||
|
throw new RuntimeException("Please follow update instructions https://www.spigotmc.org/resources/tweaks724.121057/updates", exception);
|
||||||
|
} else if (configVersion > CONFIG_VERSION) {
|
||||||
throw new RuntimeException("Did you downgrade the plugin? Remove config.yml and let the plugin re-create it", exception);
|
throw new RuntimeException("Did you downgrade the plugin? Remove config.yml and let the plugin re-create it", exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@ import eu.m724.tweaks.door.DoorKnockListener;
|
||||||
import eu.m724.tweaks.door.DoorOpenListener;
|
import eu.m724.tweaks.door.DoorOpenListener;
|
||||||
import eu.m724.tweaks.full.FullListener;
|
import eu.m724.tweaks.full.FullListener;
|
||||||
import eu.m724.tweaks.hardcore.HardcoreManager;
|
import eu.m724.tweaks.hardcore.HardcoreManager;
|
||||||
|
import eu.m724.tweaks.knockback.KnockbackListener;
|
||||||
import eu.m724.tweaks.motd.MotdManager;
|
import eu.m724.tweaks.motd.MotdManager;
|
||||||
import eu.m724.tweaks.ping.F3NameListener;
|
import eu.m724.tweaks.ping.F3NameListener;
|
||||||
import eu.m724.tweaks.ping.PingChecker;
|
import eu.m724.tweaks.ping.PingChecker;
|
||||||
|
@ -125,6 +126,9 @@ public class TweaksPlugin extends MStatsPlugin {
|
||||||
new RedstoneManager(this).init(getCommand("retstone"));
|
new RedstoneManager(this).init(getCommand("retstone"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DebugLogger.fine("Enabling Knockback");
|
||||||
|
new KnockbackListener(this);
|
||||||
|
|
||||||
/* end modules */
|
/* end modules */
|
||||||
|
|
||||||
if (config.metrics()) {
|
if (config.metrics()) {
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
package eu.m724.tweaks.auth;
|
package eu.m724.tweaks.auth;
|
||||||
|
|
||||||
|
import eu.m724.tweaks.Language;
|
||||||
import eu.m724.tweaks.TweaksConfig;
|
import eu.m724.tweaks.TweaksConfig;
|
||||||
import net.md_5.bungee.api.ChatColor;
|
import net.md_5.bungee.api.ChatColor;
|
||||||
import net.md_5.bungee.api.chat.BaseComponent;
|
import net.md_5.bungee.api.chat.BaseComponent;
|
||||||
|
@ -50,7 +51,7 @@ public class AuthCommands implements CommandExecutor {
|
||||||
.underlined(true)
|
.underlined(true)
|
||||||
.color(ChatColor.GRAY)
|
.color(ChatColor.GRAY)
|
||||||
.event(new ClickEvent(ClickEvent.Action.COPY_TO_CLIPBOARD, hostname))
|
.event(new ClickEvent(ClickEvent.Action.COPY_TO_CLIPBOARD, hostname))
|
||||||
.event(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new Text("Click to copy")))
|
.event(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new Text(Language.getString("clickToCopy"))))
|
||||||
.build();
|
.build();
|
||||||
sender.spigot().sendMessage(component);
|
sender.spigot().sendMessage(component);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -19,12 +19,11 @@ public class AuthStorage {
|
||||||
private final File keysDirectory;
|
private final File keysDirectory;
|
||||||
|
|
||||||
AuthStorage(Plugin plugin) {
|
AuthStorage(Plugin plugin) {
|
||||||
File directory = new File(plugin.getDataFolder(), "auth storage");
|
File directory = new File(plugin.getDataFolder(), "storage/auth");
|
||||||
this.playersDirectory = new File(directory, "players");
|
this.playersDirectory = new File(directory, "players");
|
||||||
this.keysDirectory = new File(directory, "keys");
|
this.keysDirectory = new File(directory, "keys");
|
||||||
|
|
||||||
directory.mkdir();
|
keysDirectory.mkdirs();
|
||||||
keysDirectory.mkdir();
|
|
||||||
playersDirectory.mkdir();
|
playersDirectory.mkdir();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,6 @@ import org.bukkit.plugin.Plugin;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
public class ChatManager {
|
public class ChatManager {
|
||||||
private final Plugin plugin;
|
private final Plugin plugin;
|
||||||
|
@ -75,7 +74,7 @@ public class ChatManager {
|
||||||
if (id.equals(defaultRoom)) {
|
if (id.equals(defaultRoom)) {
|
||||||
chatRoom = new ChatRoom(defaultRoom, null, null);
|
chatRoom = new ChatRoom(defaultRoom, null, null);
|
||||||
} else {
|
} else {
|
||||||
chatRoom = ChatRoomLoader.load(plugin, id);
|
chatRoom = ChatRoomLoader.load(id);
|
||||||
}
|
}
|
||||||
roomIdMap.put(id, chatRoom);
|
roomIdMap.put(id, chatRoom);
|
||||||
}
|
}
|
||||||
|
@ -172,17 +171,17 @@ public class ChatManager {
|
||||||
throw new ChatRoomExistsException();
|
throw new ChatRoomExistsException();
|
||||||
|
|
||||||
ChatRoom chatRoom = new ChatRoom(id, password, owner);
|
ChatRoom chatRoom = new ChatRoom(id, password, owner);
|
||||||
ChatRoomLoader.save(plugin, chatRoom);
|
ChatRoomLoader.save(chatRoom);
|
||||||
return chatRoom;
|
return chatRoom;
|
||||||
}
|
}
|
||||||
|
|
||||||
void saveChatRoom(ChatRoom chatRoom) throws IOException {
|
void saveChatRoom(ChatRoom chatRoom) throws IOException {
|
||||||
ChatRoomLoader.save(plugin, chatRoom);
|
ChatRoomLoader.save(chatRoom);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void deleteChatRoom(ChatRoom chatRoom) {
|
public void deleteChatRoom(ChatRoom chatRoom) {
|
||||||
roomIdMap.remove(chatRoom.id);
|
roomIdMap.remove(chatRoom.id);
|
||||||
ChatRoomLoader.getFile(plugin, chatRoom.id).delete();
|
ChatRoomLoader.getFile(chatRoom.id).delete();
|
||||||
chatRoom.players.forEach(player -> setPlayerChatRoom(getById(defaultRoom), player));
|
chatRoom.players.forEach(player -> setPlayerChatRoom(getById(defaultRoom), player));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,23 +13,25 @@ import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Path;
|
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class ChatRoomLoader {
|
public class ChatRoomLoader {
|
||||||
|
private static File chatRoomsDir;
|
||||||
|
|
||||||
|
static void init(Plugin plugin) {
|
||||||
|
chatRoomsDir = new File(plugin.getDataFolder(), "storage/rooms");
|
||||||
|
chatRoomsDir.mkdirs();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the file of persistent storage of a chat room
|
* Get the file of persistent storage of a chat room
|
||||||
* @return the file or null if ID is invalid
|
* @return the file or null if ID is invalid
|
||||||
*/
|
*/
|
||||||
static File getFile(Plugin plugin, String id) {
|
static File getFile(String id) {
|
||||||
Path chatRoomsPath = Paths.get(plugin.getDataFolder().getPath(), "rooms");
|
|
||||||
chatRoomsPath.toFile().mkdirs();
|
|
||||||
|
|
||||||
if (validateId(id) != 0)
|
if (validateId(id) != 0)
|
||||||
throw new RuntimeException("Invalid id: " + id);
|
throw new RuntimeException("Invalid id: " + id);
|
||||||
|
|
||||||
return Paths.get(chatRoomsPath.toFile().getPath(), id + ".yml").toFile();
|
return new File(chatRoomsDir, id + ".yml");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -62,8 +64,8 @@ public class ChatRoomLoader {
|
||||||
* @param id the id of the chat room
|
* @param id the id of the chat room
|
||||||
* @return the chat room or null if no such chat room
|
* @return the chat room or null if no such chat room
|
||||||
*/
|
*/
|
||||||
static ChatRoom load(Plugin plugin, String id) {
|
static ChatRoom load(String id) {
|
||||||
File chatRoomFile = getFile(plugin, id);
|
File chatRoomFile = getFile(id);
|
||||||
if (!chatRoomFile.exists()) return null;
|
if (!chatRoomFile.exists()) return null;
|
||||||
|
|
||||||
YamlConfiguration configuration = YamlConfiguration.loadConfiguration(chatRoomFile);
|
YamlConfiguration configuration = YamlConfiguration.loadConfiguration(chatRoomFile);
|
||||||
|
@ -89,14 +91,15 @@ public class ChatRoomLoader {
|
||||||
*
|
*
|
||||||
* @throws IOException if saving failed
|
* @throws IOException if saving failed
|
||||||
*/
|
*/
|
||||||
static void save(Plugin plugin, ChatRoom chatRoom) throws IOException {
|
static void save(ChatRoom chatRoom) throws IOException {
|
||||||
YamlConfiguration configuration = new YamlConfiguration();
|
YamlConfiguration configuration = new YamlConfiguration();
|
||||||
configuration.set("password", chatRoom.password);
|
configuration.set("password", chatRoom.password);
|
||||||
configuration.set("color", chatRoom.color.getName());
|
configuration.set("color", chatRoom.color.getName());
|
||||||
|
// TODO consider just making this str to make it easier
|
||||||
configuration.set("owner.msb", chatRoom.owner.getUniqueId().getMostSignificantBits());
|
configuration.set("owner.msb", chatRoom.owner.getUniqueId().getMostSignificantBits());
|
||||||
configuration.set("owner.lsb", chatRoom.owner.getUniqueId().getLeastSignificantBits());
|
configuration.set("owner.lsb", chatRoom.owner.getUniqueId().getLeastSignificantBits());
|
||||||
|
|
||||||
File chatRoomFile = getFile(plugin, chatRoom.id);
|
File chatRoomFile = getFile(chatRoom.id);
|
||||||
configuration.save(chatRoomFile);
|
configuration.save(chatRoomFile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,12 @@
|
||||||
package eu.m724.tweaks.redstone;
|
package eu.m724.tweaks.redstone;
|
||||||
|
|
||||||
import eu.m724.tweaks.DebugLogger;
|
import eu.m724.tweaks.DebugLogger;
|
||||||
|
import eu.m724.tweaks.Language;
|
||||||
|
import net.md_5.bungee.api.ChatColor;
|
||||||
|
import net.md_5.bungee.api.chat.ClickEvent;
|
||||||
|
import net.md_5.bungee.api.chat.ComponentBuilder;
|
||||||
|
import net.md_5.bungee.api.chat.HoverEvent;
|
||||||
|
import net.md_5.bungee.api.chat.hover.content.Text;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.block.Action;
|
import org.bukkit.event.block.Action;
|
||||||
|
@ -45,13 +51,19 @@ public class RedstoneListener implements Listener {
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onPlayerInteract(PlayerInteractEvent event) {
|
public void onPlayerInteract(PlayerInteractEvent event) {
|
||||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) return;
|
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) return;
|
||||||
if (event.getClickedBlock() == null) return;
|
if (!event.getPlayer().isSneaking()) return;
|
||||||
|
|
||||||
var id = redstoneRepeaters.getId(event.getClickedBlock());
|
var id = redstoneRepeaters.getId(event.getClickedBlock());
|
||||||
if (id == Integer.MIN_VALUE) return;
|
if (id == Integer.MIN_VALUE) return;
|
||||||
|
|
||||||
// TODO find a less lame way of showing ID
|
// TODO find a less lame way of showing ID
|
||||||
event.getPlayer().sendMessage("Repeater ID: " + id);
|
var component = new ComponentBuilder("Repeater ID: ").color(ChatColor.GOLD)
|
||||||
|
.append(String.valueOf(id)).color(ChatColor.AQUA)
|
||||||
|
.event(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new Text(Language.getString("clickToCopy"))))
|
||||||
|
.event(new ClickEvent(ClickEvent.Action.COPY_TO_CLIPBOARD, String.valueOf(id)))
|
||||||
|
.build();
|
||||||
|
|
||||||
|
event.getPlayer().spigot().sendMessage(component);
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
|
|
|
@ -29,7 +29,7 @@ public class RedstoneManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void init(PluginCommand command) {
|
public void init(PluginCommand command) {
|
||||||
Store.init(plugin);
|
RedstoneStore.init(plugin);
|
||||||
|
|
||||||
plugin.getServer().getPluginManager().registerEvents(new RedstoneListener(redstoneRepeaters), plugin);
|
plugin.getServer().getPluginManager().registerEvents(new RedstoneListener(redstoneRepeaters), plugin);
|
||||||
command.setExecutor(new RedstoneCommands(redstoneRepeaters));
|
command.setExecutor(new RedstoneCommands(redstoneRepeaters));
|
||||||
|
|
|
@ -8,6 +8,7 @@ package eu.m724.tweaks.redstone;
|
||||||
|
|
||||||
import com.google.common.collect.BiMap;
|
import com.google.common.collect.BiMap;
|
||||||
import com.google.common.collect.HashBiMap;
|
import com.google.common.collect.HashBiMap;
|
||||||
|
import eu.m724.tweaks.DebugLogger;
|
||||||
import eu.m724.tweaks.Language;
|
import eu.m724.tweaks.Language;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
@ -65,7 +66,7 @@ public class RedstoneRepeaters {
|
||||||
repeatersById.put(repeaterId, block.getLocation());
|
repeatersById.put(repeaterId, block.getLocation());
|
||||||
block.setMetadata("rid", new FixedMetadataValue(plugin, repeaterId));
|
block.setMetadata("rid", new FixedMetadataValue(plugin, repeaterId));
|
||||||
|
|
||||||
Store.getInstance().saveRepeaterData(block.getLocation(), repeaterId, (byte) 0);
|
RedstoneStore.getInstance().saveRepeaterData(block.getLocation(), repeaterId, (byte) 0);
|
||||||
|
|
||||||
return repeaterId;
|
return repeaterId;
|
||||||
}
|
}
|
||||||
|
@ -79,7 +80,7 @@ public class RedstoneRepeaters {
|
||||||
if (location == null) return;
|
if (location == null) return;
|
||||||
repeatersByPower.remove(repeaterId);
|
repeatersByPower.remove(repeaterId);
|
||||||
|
|
||||||
Store.getInstance().deleteSavedRepeaterData(location);
|
RedstoneStore.getInstance().deleteSavedRepeaterData(location);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get functions */
|
/* Get functions */
|
||||||
|
@ -89,7 +90,7 @@ public class RedstoneRepeaters {
|
||||||
// if not, we're not loading because it's loaded as the block is
|
// if not, we're not loading because it's loaded as the block is
|
||||||
var loc = repeatersById.get(repeaterId);
|
var loc = repeatersById.get(repeaterId);
|
||||||
if (loc == null) {
|
if (loc == null) {
|
||||||
System.err.println("Delete because no loc");
|
DebugLogger.fine("isValid: Delete because no loc");
|
||||||
delete(repeaterId);
|
delete(repeaterId);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -101,6 +102,7 @@ public class RedstoneRepeaters {
|
||||||
|
|
||||||
// check if the block is correct type
|
// check if the block is correct type
|
||||||
if (loc.getBlock().getType() != Material.DAYLIGHT_DETECTOR) {
|
if (loc.getBlock().getType() != Material.DAYLIGHT_DETECTOR) {
|
||||||
|
DebugLogger.fine("isValid: Delete because not sensor");
|
||||||
delete(repeaterId);
|
delete(repeaterId);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -108,7 +110,7 @@ public class RedstoneRepeaters {
|
||||||
// check if the block has the same ID bound
|
// check if the block has the same ID bound
|
||||||
var meta = loc.getBlock().getMetadata("rid");
|
var meta = loc.getBlock().getMetadata("rid");
|
||||||
if (meta.isEmpty() || meta.getFirst().asInt() != repeaterId) {
|
if (meta.isEmpty() || meta.getFirst().asInt() != repeaterId) {
|
||||||
System.err.println("Delete because no meta");
|
DebugLogger.fine("isValid: Delete because no meta");
|
||||||
delete(repeaterId);
|
delete(repeaterId);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -126,7 +128,7 @@ public class RedstoneRepeaters {
|
||||||
|
|
||||||
if (id == null) {
|
if (id == null) {
|
||||||
// not in memory, check if repeater
|
// not in memory, check if repeater
|
||||||
var d = Store.getInstance().getSavedRepeaterData(block.getLocation());
|
var d = RedstoneStore.getInstance().getSavedRepeaterData(block.getLocation());
|
||||||
|
|
||||||
if (d == null) {
|
if (d == null) {
|
||||||
block.setMetadata("rid", new FixedMetadataValue(plugin, Integer.MIN_VALUE));
|
block.setMetadata("rid", new FixedMetadataValue(plugin, Integer.MIN_VALUE));
|
||||||
|
@ -153,12 +155,13 @@ public class RedstoneRepeaters {
|
||||||
|
|
||||||
var storedId = location.getBlock().getMetadata("rid").getFirst().asInt();
|
var storedId = location.getBlock().getMetadata("rid").getFirst().asInt();
|
||||||
if (storedId != repeaterId) {
|
if (storedId != repeaterId) {
|
||||||
System.out.println("retrieved but not exitt");
|
DebugLogger.fine("attempted retrieve, but doesn't exist, deleting " + repeaterId);
|
||||||
delete(repeaterId);
|
delete(repeaterId);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
System.out.println("retrieved exist " + repeaterId);
|
DebugLogger.fine("retrieved " + repeaterId);
|
||||||
|
|
||||||
return location.getBlock();
|
return location.getBlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,20 +173,21 @@ public class RedstoneRepeaters {
|
||||||
|
|
||||||
block.getWorld().spawnParticle(Particle.LAVA, block.getLocation().add(0.5, 0.5, 0.5), 3);
|
block.getWorld().spawnParticle(Particle.LAVA, block.getLocation().add(0.5, 0.5, 0.5), 3);
|
||||||
|
|
||||||
System.out.println("Okay I got in power" + block.getBlockPower());
|
var power = (byte) block.getBlockPower();
|
||||||
return (byte) block.getBlockPower();
|
DebugLogger.fine("Got " + repeaterId + " receives " + power);
|
||||||
|
return power;
|
||||||
}
|
}
|
||||||
|
|
||||||
byte getOutboundPower(int repeaterId) {
|
byte getOutboundPower(int repeaterId) {
|
||||||
var block = getBlock(repeaterId);
|
var block = getBlock(repeaterId);
|
||||||
if (block == null) return -1;
|
if (block == null) return -1;
|
||||||
|
|
||||||
System.out.println("Okay I got out power" + repeatersByPower.get(repeaterId));
|
var power = repeatersByPower.getOrDefault(repeaterId, (byte) 0);
|
||||||
return repeatersByPower.getOrDefault(repeaterId, (byte) 0);
|
DebugLogger.fine("Got " + repeaterId + " outputs " + power);
|
||||||
|
return power;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setPower(int repeaterId, byte power) {
|
void setPower(int repeaterId, byte power) {
|
||||||
System.out.println(power);
|
|
||||||
if (power < 0 || power > 15)
|
if (power < 0 || power > 15)
|
||||||
throw new IllegalArgumentException("Power should be 0-15, but is " + power);
|
throw new IllegalArgumentException("Power should be 0-15, but is " + power);
|
||||||
|
|
||||||
|
@ -197,6 +201,6 @@ public class RedstoneRepeaters {
|
||||||
|
|
||||||
block.getWorld().spawnParticle(Particle.LAVA, block.getLocation().add(0.5, 0.5, 0.5), 3);
|
block.getWorld().spawnParticle(Particle.LAVA, block.getLocation().add(0.5, 0.5, 0.5), 3);
|
||||||
|
|
||||||
System.out.println("Okay I set power");
|
DebugLogger.fine("Set power of " + repeaterId + " to " + power);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -7,6 +7,7 @@
|
||||||
package eu.m724.tweaks.redstone;
|
package eu.m724.tweaks.redstone;
|
||||||
|
|
||||||
import com.google.common.primitives.Ints;
|
import com.google.common.primitives.Ints;
|
||||||
|
import eu.m724.tweaks.DebugLogger;
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
@ -15,23 +16,23 @@ import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
|
|
||||||
public class Store {
|
public class RedstoneStore {
|
||||||
private static Store INSTANCE;
|
private static RedstoneStore INSTANCE;
|
||||||
|
|
||||||
private final Plugin plugin;
|
private final Plugin plugin;
|
||||||
private final File directory;
|
private final File directory;
|
||||||
|
|
||||||
private Store(Plugin plugin) {
|
private RedstoneStore(Plugin plugin) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.directory = new File(plugin.getDataFolder(), "storage/redstone");
|
this.directory = new File(plugin.getDataFolder(), "storage/redstone");
|
||||||
directory.mkdirs();
|
directory.mkdirs();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void init(Plugin plugin) {
|
static void init(Plugin plugin) {
|
||||||
INSTANCE = new Store(plugin);
|
INSTANCE = new RedstoneStore(plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Store getInstance() {
|
static RedstoneStore getInstance() {
|
||||||
return INSTANCE;
|
return INSTANCE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,12 +52,13 @@ public class Store {
|
||||||
var repeaterId = Ints.fromByteArray(bytes) & ~0xF;
|
var repeaterId = Ints.fromByteArray(bytes) & ~0xF;
|
||||||
var powerLevel = (byte) (bytes[3] & 0xF);
|
var powerLevel = (byte) (bytes[3] & 0xF);
|
||||||
|
|
||||||
|
DebugLogger.fine("load " + location + " " + repeaterId + " " + powerLevel);
|
||||||
|
|
||||||
return Pair.of(repeaterId, powerLevel);
|
return Pair.of(repeaterId, powerLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
void saveRepeaterData(Location location, int repeaterId, byte powerLevel) {
|
void saveRepeaterData(Location location, int repeaterId, byte powerLevel) {
|
||||||
var file = getFile(location);
|
var file = getFile(location);
|
||||||
System.out.println(file);
|
|
||||||
byte[] bytes = Ints.toByteArray((repeaterId & ~0xF) | (powerLevel & 0xF));
|
byte[] bytes = Ints.toByteArray((repeaterId & ~0xF) | (powerLevel & 0xF));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -64,6 +66,8 @@ public class Store {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new RuntimeException("Saving repeater data", e);
|
throw new RuntimeException("Saving repeater data", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DebugLogger.fine("save " + location + " " + repeaterId + " " + powerLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
void deleteSavedRepeaterData(Location location) {
|
void deleteSavedRepeaterData(Location location) {
|
|
@ -28,7 +28,7 @@ public class UpdaterManager {
|
||||||
|
|
||||||
public UpdaterManager(Plugin plugin) {
|
public UpdaterManager(Plugin plugin) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
cacheFile = new File(plugin.getDataFolder(), "cache/updater");
|
cacheFile = new File(plugin.getDataFolder(), "storage/updater");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void init(PluginCommand updatesCommand){
|
public void init(PluginCommand updatesCommand){
|
||||||
|
|
|
@ -120,4 +120,4 @@ knockback:
|
||||||
# Finally, thank you for downloading Tweaks724, I hope you enjoy!
|
# Finally, thank you for downloading Tweaks724, I hope you enjoy!
|
||||||
|
|
||||||
# Don't modify unless told to
|
# Don't modify unless told to
|
||||||
magic number don't modify this: 1
|
magic number don't modify this: 2
|
|
@ -31,3 +31,5 @@ authKickWrongKey = You're connecting to the wrong server address. You must conne
|
||||||
authKickUnregistered = You are not whitelisted on this server!
|
authKickUnregistered = You are not whitelisted on this server!
|
||||||
|
|
||||||
retstoneBlockItem = Online redstone block
|
retstoneBlockItem = Online redstone block
|
||||||
|
|
||||||
|
clickToCopy = Click to copy to clipboard
|
Loading…
Add table
Reference in a new issue