From 9763380128cd34f0e3f2ef891c7336138c0a442e Mon Sep 17 00:00:00 2001 From: Technus Date: Wed, 4 Oct 2017 05:54:43 +0200 Subject: Fix static XSTR --- src/main/java/gregtech/api/objects/XSTR.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'src/main/java/gregtech/api') diff --git a/src/main/java/gregtech/api/objects/XSTR.java b/src/main/java/gregtech/api/objects/XSTR.java index 5ca3893d25..22bcf91dbe 100644 --- a/src/main/java/gregtech/api/objects/XSTR.java +++ b/src/main/java/gregtech/api/objects/XSTR.java @@ -43,12 +43,15 @@ public class XSTR extends Random { private static final long SEEDER_INCREMENT = 0xbb67ae8584caa73bL; private static final double DOUBLE_UNIT = 0x1.0p-53; // 1.0 / (1L << 53) private static final float FLOAT_UNIT = 0x1.0p-24f; // 1.0f / (1 << 24) + private static final AtomicLong seedUniquifier = new AtomicLong(8682522807148012L); public final static XSTR XSTR_INSTANCE=new XSTR(){ @Override public synchronized void setSeed(long seed) { - throw new NoSuchMethodError("This is meant to be shared!, leave seed state alone!"); + if(!Thread.currentThread().getStackTrace()[2].getClassName().equals(Random.class.getName())) + throw new NoSuchMethodError("This is meant to be shared!, leave seed state alone!"); } }; + /* MODIFIED BY: Robotia Modification: Implemented Random class seed generator @@ -61,8 +64,6 @@ public class XSTR extends Random { public XSTR() { this(seedUniquifier() ^ System.nanoTime()); } - private static final AtomicLong seedUniquifier - = new AtomicLong(8682522807148012L); private static long seedUniquifier() { // L'Ecuyer, "Tables of Linear Congruential Generators of -- cgit