mirror of
https://github.com/TotalFreedomMC/TF-PlotSquared.git
synced 2025-01-03 13:38:21 +00:00
Fix #938
This commit is contained in:
parent
62531a42c7
commit
b59665b00b
10 changed files with 27 additions and 22 deletions
|
@ -597,8 +597,8 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
}
|
||||||
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||||
|
|
|
@ -1726,7 +1726,7 @@ public class PS {
|
||||||
if (!output.exists()) {
|
if (!output.exists()) {
|
||||||
output.mkdirs();
|
output.mkdirs();
|
||||||
}
|
}
|
||||||
final File newFile = new File((output + File.separator + folder + File.separator + file));
|
final File newFile = MainUtil.getFile(output, folder + File.separator + file);
|
||||||
if (newFile.exists()) {
|
if (newFile.exists()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2063,6 +2063,9 @@ public class PS {
|
||||||
options.put("approval.done.required-for-download", Settings.DOWNLOAD_REQUIRES_DONE);
|
options.put("approval.done.required-for-download", Settings.DOWNLOAD_REQUIRES_DONE);
|
||||||
|
|
||||||
// Schematics
|
// Schematics
|
||||||
|
if (StringMan.isEqual(config.getString("schematic.save_path"), "plugins/PlotSquared/schematics")) {
|
||||||
|
config.set("schematics.save_path", Settings.SCHEMATIC_SAVE_PATH);
|
||||||
|
}
|
||||||
options.put("schematics.save_path", Settings.SCHEMATIC_SAVE_PATH);
|
options.put("schematics.save_path", Settings.SCHEMATIC_SAVE_PATH);
|
||||||
options.put("bo3.save_path", Settings.BO3_SAVE_PATH);
|
options.put("bo3.save_path", Settings.BO3_SAVE_PATH);
|
||||||
|
|
||||||
|
@ -2177,6 +2180,8 @@ public class PS {
|
||||||
|
|
||||||
// Schematics
|
// Schematics
|
||||||
Settings.SCHEMATIC_SAVE_PATH = config.getString("schematics.save_path");
|
Settings.SCHEMATIC_SAVE_PATH = config.getString("schematics.save_path");
|
||||||
|
|
||||||
|
|
||||||
Settings.BO3_SAVE_PATH = config.getString("bo3.save_path");
|
Settings.BO3_SAVE_PATH = config.getString("bo3.save_path");
|
||||||
|
|
||||||
// Web
|
// Web
|
||||||
|
|
|
@ -85,7 +85,7 @@ public class Database extends SubCommand {
|
||||||
MainUtil.sendMessage(player, "/plot database import [sqlite file] [prefix]");
|
MainUtil.sendMessage(player, "/plot database import [sqlite file] [prefix]");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
File file = new File(PS.get().IMP.getDirectory() + File.separator + args[1] + ".db");
|
File file = MainUtil.getFile(PS.get().IMP.getDirectory(), (args[1].endsWith(".db")) ? args[1] : args[1] + ".db");
|
||||||
if (!file.exists()) {
|
if (!file.exists()) {
|
||||||
MainUtil.sendMessage(player, "&6Database does not exist: " + file);
|
MainUtil.sendMessage(player, "&6Database does not exist: " + file);
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -269,7 +269,7 @@ public class DebugExec extends SubCommand {
|
||||||
case "addcmd":
|
case "addcmd":
|
||||||
try {
|
try {
|
||||||
final String cmd = StringMan.join(Files
|
final String cmd = StringMan.join(Files
|
||||||
.readLines(new File(new File(PS.get().IMP.getDirectory() + File.separator + "scripts"), args[1]),
|
.readLines(MainUtil.getFile(new File(PS.get().IMP.getDirectory() + File.separator + "scripts"), args[1]),
|
||||||
StandardCharsets.UTF_8),
|
StandardCharsets.UTF_8),
|
||||||
System.getProperty("line.separator"));
|
System.getProperty("line.separator"));
|
||||||
final Command<PlotPlayer> subcommand = new Command<PlotPlayer>(args[1].split("\\.")[0]) {
|
final Command<PlotPlayer> subcommand = new Command<PlotPlayer>(args[1].split("\\.")[0]) {
|
||||||
|
@ -298,7 +298,7 @@ public class DebugExec extends SubCommand {
|
||||||
async = true;
|
async = true;
|
||||||
case "run":
|
case "run":
|
||||||
try {
|
try {
|
||||||
script = StringMan.join(Files.readLines(new File(new File(PS.get().IMP.getDirectory() + File.separator + "scripts"), args[1]), StandardCharsets.UTF_8),
|
script = StringMan.join(Files.readLines(MainUtil.getFile(new File(PS.get().IMP.getDirectory() + File.separator + "scripts"), args[1]), StandardCharsets.UTF_8),
|
||||||
System.getProperty("line.separator"));
|
System.getProperty("line.separator"));
|
||||||
if (args.length > 2) {
|
if (args.length > 2) {
|
||||||
final HashMap<String, String> replacements = new HashMap<>();
|
final HashMap<String, String> replacements = new HashMap<>();
|
||||||
|
|
|
@ -21,25 +21,16 @@
|
||||||
package com.intellectualcrafters.plot.commands;
|
package com.intellectualcrafters.plot.commands;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.PS;
|
import com.intellectualcrafters.plot.PS;
|
||||||
import com.intellectualcrafters.plot.object.ChunkLoc;
|
|
||||||
import com.intellectualcrafters.plot.object.Location;
|
|
||||||
import com.intellectualcrafters.plot.object.PlotPlayer;
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
import com.intellectualcrafters.plot.util.MainUtil;
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
import com.intellectualcrafters.plot.util.SetQueue;
|
|
||||||
import com.intellectualcrafters.plot.util.StringMan;
|
import com.intellectualcrafters.plot.util.StringMan;
|
||||||
import com.plotsquared.general.commands.CommandDeclaration;
|
import com.plotsquared.general.commands.CommandDeclaration;
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
|
|
||||||
@CommandDeclaration(command = "plugin", permission = "plots.use", description = "Show plugin information", aliases = { "version" }, category = CommandCategory.INFO)
|
@CommandDeclaration(command = "plugin", permission = "plots.use", description = "Show plugin information", aliases = { "version" }, category = CommandCategory.INFO)
|
||||||
public class plugin extends SubCommand {
|
public class plugin extends SubCommand {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCommand(final PlotPlayer plr, final String[] args) {
|
public boolean onCommand(final PlotPlayer plr, final String[] args) {
|
||||||
Location loc = plr.getLocation();
|
|
||||||
ChunkLoc cl = loc.getChunkLoc();
|
|
||||||
SetQueue.IMP.queue.sendChunk(loc.getWorld(), Collections.singletonList(cl));
|
|
||||||
|
|
||||||
MainUtil.sendMessage(plr, String.format("$2>> $1&lPlotSquared $2($1Version$2: $1%s$2)", StringMan.join(PS.get().IMP.getPluginVersion(), ".")));
|
MainUtil.sendMessage(plr, String.format("$2>> $1&lPlotSquared $2($1Version$2: $1%s$2)", StringMan.join(PS.get().IMP.getPluginVersion(), ".")));
|
||||||
MainUtil.sendMessage(plr, "$2>> $1&lAuthors$2: $1Citymonstret $2& $1Empire92");
|
MainUtil.sendMessage(plr, "$2>> $1&lAuthors$2: $1Citymonstret $2& $1Empire92");
|
||||||
MainUtil.sendMessage(plr, "$2>> $1&lWiki$2: $1https://github.com/IntellectualCrafters/PlotSquared/wiki");
|
MainUtil.sendMessage(plr, "$2>> $1&lWiki$2: $1https://github.com/IntellectualCrafters/PlotSquared/wiki");
|
||||||
|
|
|
@ -113,7 +113,7 @@ public class Settings {
|
||||||
/**
|
/**
|
||||||
* Schematic Save Path
|
* Schematic Save Path
|
||||||
*/
|
*/
|
||||||
public static String SCHEMATIC_SAVE_PATH = "plugins/PlotSquared/schematics";
|
public static String SCHEMATIC_SAVE_PATH = "schematics";
|
||||||
/**
|
/**
|
||||||
* BO3 Save Path
|
* BO3 Save Path
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -185,9 +185,9 @@ public class BO3Handler {
|
||||||
}
|
}
|
||||||
File bo3File;
|
File bo3File;
|
||||||
if ((bo3.getLoc().x == 0) && (bo3.getLoc().z == 0)) {
|
if ((bo3.getLoc().x == 0) && (bo3.getLoc().z == 0)) {
|
||||||
bo3File = new File(base.getParentFile(), bo3.getName() + ".bo3");
|
bo3File = MainUtil.getFile(base.getParentFile(), bo3.getName() + ".bo3");
|
||||||
} else {
|
} else {
|
||||||
bo3File = new File(base.getParentFile(), bo3.getName() + "_" + bo3.getLoc().x + "_" + bo3.getLoc().z + ".bo3");
|
bo3File = MainUtil.getFile(base.getParentFile(), bo3.getName() + "_" + bo3.getLoc().x + "_" + bo3.getLoc().z + ".bo3");
|
||||||
}
|
}
|
||||||
bo3File.createNewFile();
|
bo3File.createNewFile();
|
||||||
Files.write(bo3File.toPath(), StringMan.join(lines, System.getProperty("line.separator")).getBytes(), StandardOpenOption.WRITE);
|
Files.write(bo3File.toPath(), StringMan.join(lines, System.getProperty("line.separator")).getBytes(), StandardOpenOption.WRITE);
|
||||||
|
@ -199,7 +199,7 @@ public class BO3Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static File getBaseFile(final String category) {
|
public static File getBaseFile(final String category) {
|
||||||
final File base = new File(PS.get().IMP.getDirectory(), Settings.BO3_SAVE_PATH + File.separator + category + File.separator + "base.yml");
|
final File base = MainUtil.getFile(PS.get().IMP.getDirectory(), Settings.BO3_SAVE_PATH + File.separator + category + File.separator + "base.yml");
|
||||||
if (!base.exists()) {
|
if (!base.exists()) {
|
||||||
PS.get().copyFile("base.yml", Settings.BO3_SAVE_PATH + File.separator + category);
|
PS.get().copyFile("base.yml", Settings.BO3_SAVE_PATH + File.separator + category);
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,8 @@ import com.intellectualcrafters.plot.flag.Flag;
|
||||||
import com.intellectualcrafters.plot.flag.FlagManager;
|
import com.intellectualcrafters.plot.flag.FlagManager;
|
||||||
import com.intellectualcrafters.plot.object.*;
|
import com.intellectualcrafters.plot.object.*;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.nio.file.Paths;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
|
@ -417,6 +419,13 @@ public class MainUtil {
|
||||||
SetQueue.IMP.queue.sendChunk(world, Collections.singletonList(loc));
|
SetQueue.IMP.queue.sendChunk(world, Collections.singletonList(loc));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static File getFile(File base, String path) {
|
||||||
|
if (Paths.get(path).isAbsolute()) {
|
||||||
|
return new File(path);
|
||||||
|
}
|
||||||
|
return new File(base, path);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a cuboid in the world to a set of blocks.
|
* Set a cuboid in the world to a set of blocks.
|
||||||
* @param world
|
* @param world
|
||||||
|
|
|
@ -450,13 +450,13 @@ public abstract class SchematicHandler {
|
||||||
* @return schematic if found, else null
|
* @return schematic if found, else null
|
||||||
*/
|
*/
|
||||||
public Schematic getSchematic(final String name) {
|
public Schematic getSchematic(final String name) {
|
||||||
final File parent = new File(PS.get().IMP.getDirectory() + File.separator + "schematics");
|
final File parent = MainUtil.getFile(PS.get().IMP.getDirectory(), Settings.SCHEMATIC_SAVE_PATH);
|
||||||
if (!parent.exists()) {
|
if (!parent.exists()) {
|
||||||
if (!parent.mkdir()) {
|
if (!parent.mkdir()) {
|
||||||
throw new RuntimeException("Could not create schematic parent directory");
|
throw new RuntimeException("Could not create schematic parent directory");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final File file = new File(PS.get().IMP.getDirectory() + File.separator + "schematics" + File.separator + name + (name.endsWith(".schematic") ? "" : ".schematic"));
|
final File file = MainUtil.getFile(PS.get().IMP.getDirectory(), Settings.SCHEMATIC_SAVE_PATH + File.separator + name + (name.endsWith(".schematic") ? "" : ".schematic"));
|
||||||
return getSchematic(file);
|
return getSchematic(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -616,9 +616,9 @@ public abstract class SchematicHandler {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
final File tmp = new File(path);
|
final File tmp = MainUtil.getFile(PS.get().IMP.getDirectory(), path);
|
||||||
tmp.getParentFile().mkdirs();
|
tmp.getParentFile().mkdirs();
|
||||||
try (OutputStream stream = new FileOutputStream(path); NBTOutputStream output = new NBTOutputStream(new GZIPOutputStream(stream))) {
|
try (OutputStream stream = new FileOutputStream(tmp); NBTOutputStream output = new NBTOutputStream(new GZIPOutputStream(stream))) {
|
||||||
output.writeTag(tag);
|
output.writeTag(tag);
|
||||||
}
|
}
|
||||||
} catch (final IOException e) {
|
} catch (final IOException e) {
|
||||||
|
|
Binary file not shown.
Loading…
Reference in a new issue