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)
This commit is contained in:
md_5 2013-12-13 11:28:47 +11:00
parent 269a2f7635
commit 704728d670
2 changed files with 36 additions and 33 deletions

View file

@ -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 );
+ } + }
+ +

View file

@ -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 );
+ } + }