geforkt von Mirrors/Paper
Split out the configuration of engine modes 1 and 2 to eliminate the block lag seen when mining stone or wood and using engine mode 1.
Now we maintain a new list of blocks to replace with ores in engine mode 2, to ensure that we only update when players mine blocks that are potentially not an ore. We could perhaps even elimate this slight lag from mode 2 by reducing the need for calling update(x,y,z) By: md_5 <git@md-5.net>
Dieser Commit ist enthalten in:
Ursprung
9f9133e482
Commit
9a3140c935
@ -1,4 +1,4 @@
|
|||||||
From c43f6a61f267c258f692714f79098b096fc8c176 Mon Sep 17 00:00:00 2001
|
From 64d8f6301c45ffcaa96adc2efaa76226dc944bea Mon Sep 17 00:00:00 2001
|
||||||
From: md_5 <md_5@live.com.au>
|
From: md_5 <md_5@live.com.au>
|
||||||
Date: Sun, 7 Jul 2013 09:32:53 +1000
|
Date: Sun, 7 Jul 2013 09:32:53 +1000
|
||||||
Subject: [PATCH] Spigot Configuration
|
Subject: [PATCH] Spigot Configuration
|
||||||
@ -94,7 +94,7 @@ index 15a5a5d..93e1782 100644
|
|||||||
|
|
||||||
diff --git a/src/main/java/org/spigotmc/SpigotConfig.java b/src/main/java/org/spigotmc/SpigotConfig.java
|
diff --git a/src/main/java/org/spigotmc/SpigotConfig.java b/src/main/java/org/spigotmc/SpigotConfig.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000..e7f6401
|
index 0000000..3dfe4ed
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/src/main/java/org/spigotmc/SpigotConfig.java
|
+++ b/src/main/java/org/spigotmc/SpigotConfig.java
|
||||||
@@ -0,0 +1,120 @@
|
@@ -0,0 +1,120 @@
|
||||||
@ -144,8 +144,8 @@ index 0000000..e7f6401
|
|||||||
+
|
+
|
||||||
+ commands = new HashMap<String, Command>();
|
+ commands = new HashMap<String, Command>();
|
||||||
+
|
+
|
||||||
+ version = getInt( "config-version", 4 );
|
+ version = getInt( "config-version", 5 );
|
||||||
+ set( "config-version", 4 );
|
+ set( "config-version", 5 );
|
||||||
+ readConfig( SpigotConfig.class, null );
|
+ readConfig( SpigotConfig.class, null );
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
From 0aa2dc80f6bb2afd62e23f03f43beca2a1a78cee Mon Sep 17 00:00:00 2001
|
From 0c34e90fdc674988a33993715d0a2b974f87bea8 Mon Sep 17 00:00:00 2001
|
||||||
From: md_5 <md_5@live.com.au>
|
From: md_5 <md_5@live.com.au>
|
||||||
Date: Thu, 16 May 2013 18:51:05 +1000
|
Date: Thu, 16 May 2013 18:51:05 +1000
|
||||||
Subject: [PATCH] Orebfuscator
|
Subject: [PATCH] Orebfuscator
|
||||||
@ -128,10 +128,10 @@ index b990081..04f5ed1 100644
|
|||||||
public void b(int i, int j, int k, Block block, int l) {
|
public void b(int i, int j, int k, Block block, int l) {
|
||||||
diff --git a/src/main/java/org/spigotmc/AntiXray.java b/src/main/java/org/spigotmc/AntiXray.java
|
diff --git a/src/main/java/org/spigotmc/AntiXray.java b/src/main/java/org/spigotmc/AntiXray.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000..6413ac0
|
index 0000000..297fae8
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/src/main/java/org/spigotmc/AntiXray.java
|
+++ b/src/main/java/org/spigotmc/AntiXray.java
|
||||||
@@ -0,0 +1,204 @@
|
@@ -0,0 +1,200 @@
|
||||||
+package org.spigotmc;
|
+package org.spigotmc;
|
||||||
+
|
+
|
||||||
+import gnu.trove.set.TByteSet;
|
+import gnu.trove.set.TByteSet;
|
||||||
@ -148,30 +148,26 @@ index 0000000..6413ac0
|
|||||||
+ // Used to keep track of which blocks to obfuscate
|
+ // Used to keep track of which blocks to obfuscate
|
||||||
+ private final boolean[] obfuscateBlocks = new boolean[ Short.MAX_VALUE ];
|
+ private final boolean[] obfuscateBlocks = new boolean[ Short.MAX_VALUE ];
|
||||||
+ // Used to select a random replacement ore
|
+ // Used to select a random replacement ore
|
||||||
+ private byte[] replacementOres;
|
+ private final byte[] replacementOres;
|
||||||
+
|
+
|
||||||
+ public AntiXray(SpigotWorldConfig config)
|
+ public AntiXray(SpigotWorldConfig config)
|
||||||
+ {
|
+ {
|
||||||
+ // Set all listed blocks as true to be obfuscated
|
+ // Set all listed blocks as true to be obfuscated
|
||||||
+ for ( int id : config.blocks )
|
+ for ( int id : ( config.engineMode == 1 ) ? config.hiddenBlocks : config.replaceBlocks )
|
||||||
+ {
|
+ {
|
||||||
+ obfuscateBlocks[id] = true;
|
+ obfuscateBlocks[id] = true;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ // For every block
|
+ // For every block
|
||||||
+ TByteSet blocks = new TByteHashSet();
|
+ TByteSet blocks = new TByteHashSet();
|
||||||
+ for ( int i = 0; i < obfuscateBlocks.length; i++ )
|
+ for ( Integer i : config.hiddenBlocks )
|
||||||
+ {
|
+ {
|
||||||
+ // If we are obfuscating it
|
+ Block block = Block.e( i );
|
||||||
+ if ( obfuscateBlocks[i] )
|
+ // Check it exists and is not a tile entity
|
||||||
|
+ if ( block != null && !block.isTileEntity() )
|
||||||
+ {
|
+ {
|
||||||
+ Block block = Block.e(i);
|
+ // Add it to the set of replacement blocks
|
||||||
+ // Check it exists and is not a tile entity
|
+ blocks.add( (byte) (int) i );
|
||||||
+ if ( block != null && !block.isTileEntity() )
|
|
||||||
+ {
|
|
||||||
+ // Add it to the set of replacement blocks
|
|
||||||
+ blocks.add( (byte) i );
|
|
||||||
+ }
|
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ // Bake it to a flat array of replacements
|
+ // Bake it to a flat array of replacements
|
||||||
@ -337,7 +333,7 @@ index 0000000..6413ac0
|
|||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||||
index 447581d..b4d9fc0 100644
|
index 447581d..b207c02 100644
|
||||||
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||||
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||||
@@ -1,5 +1,6 @@
|
@@ -1,5 +1,6 @@
|
||||||
@ -347,32 +343,39 @@ index 447581d..b4d9fc0 100644
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.configuration.file.YamlConfiguration;
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
@@ -206,4 +207,29 @@ public class SpigotWorldConfig
|
@@ -206,4 +207,36 @@ public class SpigotWorldConfig
|
||||||
arrowDespawnRate = getInt( "arrow-despawn-rate", 1200 );
|
arrowDespawnRate = getInt( "arrow-despawn-rate", 1200 );
|
||||||
log( "Arrow Despawn Rate: " + arrowDespawnRate );
|
log( "Arrow Despawn Rate: " + arrowDespawnRate );
|
||||||
}
|
}
|
||||||
+
|
+
|
||||||
+ public boolean antiXray = true;
|
+ public boolean antiXray;
|
||||||
+ public int engineMode = 1;
|
+ public int engineMode;
|
||||||
+ public List<Integer> blocks = Arrays.asList( new Integer[]
|
+ public List<Integer> hiddenBlocks;
|
||||||
+ {
|
+ public List<Integer> replaceBlocks;
|
||||||
+ 1, 5, 14, 15, 16, 21, 48, 49, 54, 56, 73, 74, 82, 129, 130
|
|
||||||
+ } );
|
|
||||||
+ public AntiXray antiXrayInstance;
|
+ public AntiXray antiXrayInstance;
|
||||||
+ private void antiXray()
|
+ private void antiXray()
|
||||||
+ {
|
+ {
|
||||||
+ antiXray = getBoolean( "anti-xray.enabled", antiXray );
|
+ antiXray = getBoolean( "anti-xray.enabled", true );
|
||||||
+ log( "Anti X-Ray: " + antiXray );
|
+ log( "Anti X-Ray: " + antiXray );
|
||||||
+
|
+
|
||||||
+ engineMode = getInt( "anti-xray.engine-mode", engineMode );
|
+ engineMode = getInt( "anti-xray.engine-mode", 1 );
|
||||||
+ log( "\tEngine Mode: " + engineMode );
|
+ log( "\tEngine Mode: " + engineMode );
|
||||||
+
|
+
|
||||||
+ if ( SpigotConfig.version < 3 )
|
+ if ( SpigotConfig.version < 5 )
|
||||||
+ {
|
+ {
|
||||||
+ set( "anti-xray.blocks", blocks );
|
+ set( "anti-xray.blocks", null );
|
||||||
+ }
|
+ }
|
||||||
+ blocks = getList( "anti-xray.blocks", blocks );
|
+ hiddenBlocks = getList( "anti-xray.hide-blocks", Arrays.asList( new Integer[]
|
||||||
+ log( "\tBlocks: " + blocks );
|
+ {
|
||||||
|
+ 14, 15, 16, 21, 48, 49, 54, 56, 73, 74, 82, 129, 130
|
||||||
|
+ } ) );
|
||||||
|
+ log( "\tHidden Blocks: " + hiddenBlocks );
|
||||||
|
+
|
||||||
|
+ replaceBlocks = getList( "anti-xray.replace-blocks", Arrays.asList( new Integer[]
|
||||||
|
+ {
|
||||||
|
+ 1, 5
|
||||||
|
+ } ) );
|
||||||
|
+ log( "\tReplace Blocks: " + hiddenBlocks );
|
||||||
+
|
+
|
||||||
+ antiXrayInstance = new AntiXray( this );
|
+ antiXrayInstance = new AntiXray( this );
|
||||||
+ }
|
+ }
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren