aboutsummaryrefslogtreecommitdiff
path: root/src/Java/gtPlusPlus/api
diff options
context:
space:
mode:
Diffstat (limited to 'src/Java/gtPlusPlus/api')
-rw-r--r--src/Java/gtPlusPlus/api/analytics/AnalyticsLoggingPlugin.java39
-rw-r--r--src/Java/gtPlusPlus/api/analytics/BlockingFlush.java67
-rw-r--r--src/Java/gtPlusPlus/api/analytics/SegmentAnalytics.java271
-rw-r--r--src/Java/gtPlusPlus/api/analytics/SegmentHelper.java81
-rw-r--r--src/Java/gtPlusPlus/api/damage/BaseCustomDamageSource.java22
-rw-r--r--src/Java/gtPlusPlus/api/damage/DamageTeslaTower.java2
-rw-r--r--src/Java/gtPlusPlus/api/enums/Quality.java62
-rw-r--r--src/Java/gtPlusPlus/api/helpers/MaterialHelper.java (renamed from src/Java/gtPlusPlus/api/objects/MaterialHelper.java)8
-rw-r--r--src/Java/gtPlusPlus/api/interfaces/IEntityCatcher.java3
-rw-r--r--src/Java/gtPlusPlus/api/interfaces/IGregtechPower.java147
-rw-r--r--src/Java/gtPlusPlus/api/interfaces/IPlugin.java6
-rw-r--r--src/Java/gtPlusPlus/api/interfaces/ITexturedBlock.java3
-rw-r--r--src/Java/gtPlusPlus/api/objects/Logger.java1
-rw-r--r--src/Java/gtPlusPlus/api/objects/data/AutoMap.java84
-rw-r--r--src/Java/gtPlusPlus/api/objects/data/Pair.java27
-rw-r--r--src/Java/gtPlusPlus/api/objects/data/Quad.java33
-rw-r--r--src/Java/gtPlusPlus/api/objects/data/Triplet.java27
-rw-r--r--src/Java/gtPlusPlus/api/objects/minecraft/BlockPos.java222
-rw-r--r--src/Java/gtPlusPlus/api/objects/minecraft/ChunkManager.java (renamed from src/Java/gtPlusPlus/api/objects/ChunkManager.java)30
-rw-r--r--src/Java/gtPlusPlus/api/objects/minecraft/DimChunkPos.java (renamed from src/Java/gtPlusPlus/api/objects/DimChunkPos.java)3
-rw-r--r--src/Java/gtPlusPlus/api/objects/minecraft/FluidGT6.java31
-rw-r--r--src/Java/gtPlusPlus/api/objects/minecraft/GenericStack.java (renamed from src/Java/gtPlusPlus/api/objects/GenericStack.java)3
-rw-r--r--src/Java/gtPlusPlus/api/objects/random/CSPRNG_DO_NOT_USE.java (renamed from src/Java/gtPlusPlus/api/objects/CSPRNG_DO_NOT_USE.java)2
-rw-r--r--src/Java/gtPlusPlus/api/objects/random/UUIDGenerator.java449
-rw-r--r--src/Java/gtPlusPlus/api/objects/random/XSTR.java (renamed from src/Java/gtPlusPlus/api/objects/XSTR.java)2
-rw-r--r--src/Java/gtPlusPlus/api/plugin/Sample_Plugin.java32
26 files changed, 1143 insertions, 514 deletions
diff --git a/src/Java/gtPlusPlus/api/analytics/AnalyticsLoggingPlugin.java b/src/Java/gtPlusPlus/api/analytics/AnalyticsLoggingPlugin.java
deleted file mode 100644
index 2423eaa65c..0000000000
--- a/src/Java/gtPlusPlus/api/analytics/AnalyticsLoggingPlugin.java
+++ /dev/null
@@ -1,39 +0,0 @@
-package gtPlusPlus.api.analytics;
-
-import com.segment.analytics.Analytics;
-import com.segment.analytics.Callback;
-import com.segment.analytics.Log;
-import com.segment.analytics.Plugin;
-import com.segment.analytics.messages.Message;
-
-import gtPlusPlus.api.objects.Logger;
-
-/**
- * A {@link Plugin} implementation that redirects client logs to standard output and logs callback
- * events.
- */
-public class AnalyticsLoggingPlugin implements Plugin {
- @Override public void configure(Analytics.Builder builder) {
- builder.log(new Log() {
- @Override public void print(Level level, String format, Object... args) {
- Logger.WARNING(level + ":\t" + String.format(format, args));
- }
-
- @Override public void print(Level level, Throwable error, String format, Object... args) {
- Logger.WARNING(level + ":\t" + String.format(format, args));
- //Utils.LOG_WARNING(error);
- }
- });
-
- builder.callback(new Callback() {
- @Override public void success(Message message) {
- Logger.WARNING("Uploaded " + message);
- }
-
- @Override public void failure(Message message, Throwable throwable) {
- Logger.WARNING("Could not upload " + message);
- //Utils.LOG_WARNING(throwable);
- }
- });
- }
-} \ No newline at end of file
diff --git a/src/Java/gtPlusPlus/api/analytics/BlockingFlush.java b/src/Java/gtPlusPlus/api/analytics/BlockingFlush.java
deleted file mode 100644
index dddb37fefb..0000000000
--- a/src/Java/gtPlusPlus/api/analytics/BlockingFlush.java
+++ /dev/null
@@ -1,67 +0,0 @@
-package gtPlusPlus.api.analytics;
-
-import com.segment.analytics.Analytics;
-import com.segment.analytics.Callback;
-import com.segment.analytics.MessageTransformer;
-import com.segment.analytics.Plugin;
-import com.segment.analytics.messages.Message;
-import com.segment.analytics.messages.MessageBuilder;
-import java.util.concurrent.Phaser;
-
-/**
- * The {@link Analytics} class doesn't come with a blocking {@link Analytics#flush()} implementation
- * out of the box. It's trivial to build one using a {@link Phaser} that monitors requests and is
- * able to block until they're uploaded.
- *
- * <pre><code>
- * BlockingFlush mBlockingFlush = BlockingFlush.create();
- * Analytics mHelper = Analytics.builder(writeKey)
- * .plugin(mBlockingFlush)
- * .build();
- *
- * // Do some work.
- *
- * mHelper.flush(); // Trigger a flush.
- * mBlockingFlush.block(); // Block until the flush completes.
- * mHelper.shutdown(); // Shut down after the flush is complete.
- * </code></pre>
- */
-public class BlockingFlush {
-
- public static BlockingFlush create() {
- return new BlockingFlush();
- }
-
- BlockingFlush() {
- this.phaser = new Phaser(1);
- }
-
- final Phaser phaser;
-
- public Plugin plugin() {
- return new Plugin() {
- @Override public void configure(Analytics.Builder builder) {
- builder.messageTransformer(new MessageTransformer() {
- @Override public boolean transform(MessageBuilder builder) {
- phaser.register();
- return true;
- }
- });
-
- builder.callback(new Callback() {
- @Override public void success(Message message) {
- phaser.arrive();
- }
-
- @Override public void failure(Message message, Throwable throwable) {
- phaser.arrive();
- }
- });
- }
- };
- }
-
- public void block() {
- phaser.arriveAndAwaitAdvance();
- }
-} \ No newline at end of file
diff --git a/src/Java/gtPlusPlus/api/analytics/SegmentAnalytics.java b/src/Java/gtPlusPlus/api/analytics/SegmentAnalytics.java
deleted file mode 100644
index c4ef82b9ef..0000000000
--- a/src/Java/gtPlusPlus/api/analytics/SegmentAnalytics.java
+++ /dev/null
@@ -1,271 +0,0 @@
-package gtPlusPlus.api.analytics;
-
-import java.util.LinkedHashMap;
-import java.util.Map;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.UUID;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.Phaser;
-
-import com.mojang.authlib.GameProfile;
-import com.segment.analytics.Analytics;
-
-import gtPlusPlus.api.objects.Logger;
-import gtPlusPlus.core.lib.CORE;
-import gtPlusPlus.core.lib.LoadedMods;
-import gtPlusPlus.core.util.Utils;
-import gtPlusPlus.core.util.player.PlayerUtils;
-import gtPlusPlus.core.util.uuid.UUIDGenerator;
-import gtPlusPlus.core.util.uuid.UUIDUtils;
-import ic2.core.IC2;
-import net.minecraft.entity.player.EntityPlayer;
-
-public class SegmentAnalytics {
-
- //Globally Enabled
- public static boolean isEnabled = true;
-
- //Analytics Map with IDs
- public static final Map<Integer, SegmentAnalytics> sAnalyticsMasterList = new ConcurrentHashMap<Integer, SegmentAnalytics>();
- //ID count
- private static int sAnalyticsMapID = 0;
-
- //Analytics Player Mapping
- public static final Map<UUID, Integer> sAnalyticsToPlayermap = new ConcurrentHashMap<UUID, Integer>();
-
- //Set some Vars
- final BlockingFlush mBlockingFlush;
- final SegmentHelper mHelper;
- final UUIDGenerator mUuidGenerator;
-
- public final GameProfile mLocalProfile;
- public final String mLocalName;
- public final UUID mUUID;
- public final String mUserName;
- public final String mAnonymousId;
- protected Map<String, Object> mProperties = new LinkedHashMap<>();
- final protected Phaser mPhaser;
-
- //Build a new instance of this class
- public SegmentAnalytics(EntityPlayer mPlayer){
- LOG("Initializing Segment for "+mPlayer.getDisplayName());
-
- //Give this Object an ID
- int currentID = sAnalyticsMapID;
- sAnalyticsMapID++;
-
- //Map this Object to it's ID and a Player UUID.
- sAnalyticsMasterList.put(currentID, this);
- sAnalyticsToPlayermap.put(mPlayer.getUniqueID(), currentID);
-
- //Create a Phaser
- this.mPhaser = new Phaser(1);
-
- //Set vars for player
- this.mLocalProfile = mPlayer.getGameProfile();
- this.mLocalName = mLocalProfile.getName();
- this.mUUID = PlayerUtils.getPlayersUUIDByName(mLocalName);
- this.mUserName = mUUID.toString();
- this.mAnonymousId = getStringForm(generateIdForSession());
-
- //Create a new UUID generator.
- this.mUuidGenerator = new UUIDGenerator();
-
- //Use Segment Analytics instead of plain Google Analytics.
- this.mBlockingFlush = BlockingFlush.create();
- this.mHelper = SegmentHelper.getInstance();
- initTimer(mPlayer);
- }
-
- //Sets vars and stops Analytics running if the player profile is invalid.
- private boolean canProcess(){
- //Invalid Player Profile
- if (mLocalProfile == null || !isEnabled){
- return false;
- }
- if (mLocalName == null || mUUID == null || mUserName == null || mAnonymousId == null){
- //LOG("One player var remained null, returning false.");
- return false;
- }
- if (mLocalName != null && mUUID != null && mUserName != null && mAnonymousId != null){
- //LOG("All player vars are ok, returning true.");
- return true;
- }
- LOG("Something went wrong, returning false.");
- return false;
- }
-
-
- public void submitInitData(EntityPlayer mPlayer){
- if (!canProcess()){
- return;
- }
- mProperties = new LinkedHashMap<>();
- mProperties.put("username", mLocalName);
- mProperties.put("gt_version", Utils.getGregtechVersionAsString());
- if (LoadedMods.IndustrialCraft2){
- mProperties.put("ic2_version", IC2.VERSION);
- }
- mProperties.put("country_code", CORE.USER_COUNTRY);
- mProperties.put("gtnh", CORE.GTNH);
-
- LOG("Created new Data packet, queued for submission.");
-
- //Old Code, now passed to Helper Class
- /*mHelper.enqueue(IdentifyMessage.builder()
- .userId(mUserName) //Save Username as UUID, for future sessions to attach to.
- .traits(mProperties)
- //.anonymousId(mAnonymousId) //Save Random Session UUID
- );*/
-
- mHelper.addUser(this.mUserName, mProperties);
-
- if (CORE.GTNH){
- mHelper.groupUser("GT:NewHorizons", this.mUserName);
- }
- else {
- mHelper.groupUser("GT:Vanilla", this.mUserName);
- }
-
- }
-
- public void submitTrackingData(String aActionPerformed){
- submitTrackingData(aActionPerformed, null);
- }
-
- public void submitTrackingData(String aActionPerformed, Object aObject){
- if (!canProcess()){
- return;
- }
-
- Map<String, Object> properties = new LinkedHashMap<>();
- properties.put("blockType", aObject);
- String mObjectAsString = "Unknown";
-
- if (aObject != null){
- mObjectAsString = aObject.toString();
- }
-
- LOG("Queued submission of data for event "+aActionPerformed+". This was performed on "+mObjectAsString+".");
-
- mHelper.trackUser(this.mUserName, aActionPerformed, properties);
-
- //Old Code, now passed to Helper Class
- /*mHelper.enqueue(TrackMessage.builder(aActionPerformed) //
- .userId(mUserName) // Save Username as UUID, for future sessions to attach to.
- .properties(mProperties) //Save Stats
- //.anonymousId(mAnonymousId) //Save Random Session UUID
- );
- flushData();
- */
- }
-
- public void flushData(){
- getAnalyticObject().flush();
- }
-
- public void flushDataFinal(){
- LOG("Flushing all data from Queue to Segment Analytics database.");
- getAnalyticObject().flush();
- mBlockingFlush.block();
- mPhaser.arriveAndAwaitAdvance();
- getAnalyticObject().shutdown();
- /*try {
- this.finalize();
- }
- catch (Throwable e) {
- Utils.LOG_INFO("Could not finalize Analytics Object.");
- }*/
- }
-
- public UUID generateIdForSession(){
- return UUIDUtils.getUUIDFromBytes(generateUUID());
- }
-
- private final byte[] generateUUID(){
- byte[] mUUID;
-
- if (this.mUuidGenerator != null){
- try {
- if ((mUUID = mUuidGenerator.next(4)) != null){
- LOG("Generated Type 4 UUID for Session ID.");
- return mUUID;
- }
- else if ((mUUID = mUuidGenerator.next(1)) != null){
- LOG("Generated Type 1 UUID for Session ID.");
- return mUUID;
- }
- }
- catch (Throwable t){
- t.printStackTrace();
- }
- }
-
- LOG("Generated Type 3 UUID for Session ID.");
- return UUIDUtils.getBytesFromUUID(UUID.randomUUID());
-
- }
-
- public final String getStringForm(UUID mID){
- return mID.toString();
- }
-
- // Non-Dev Comments
- public static void LOG(final String s) {
- if (CORE.DEBUG){
- Logger.getLogger().info("[Analytics] "+s);
- }
- }
-
- public static SegmentAnalytics getAnalyticsForPlayer(EntityPlayer mPlayer){
- try {
- if (mPlayer != null){
- if (SegmentAnalytics.sAnalyticsToPlayermap.containsKey(mPlayer.getUniqueID())){
- int ID = sAnalyticsToPlayermap.get(mPlayer.getUniqueID());
- return SegmentAnalytics.sAnalyticsMasterList.get(ID);
- }
- else {
- LOG("Map does not contain Player.");
- }
- }
- else {
- LOG("Invalid Player.");
- }
- }
- catch (Throwable t){
- t.printStackTrace();
- }
- return null;
- }
-
- public final Analytics getAnalyticObject() {
- return mHelper.getAnalyticsClient();
- }
-
- public final Map<String, Object> getPlayerProperties(){
- return this.mProperties;
- }
-
-
- public Timer initTimer(EntityPlayer mPlayer) {
- Timer timer;
- timer = new Timer();
- timer.schedule(new initPlayer(mPlayer), 2 * 1000);
- return timer;
- }
-
- //Timer Task for notifying the player.
- class initPlayer extends TimerTask {
- final EntityPlayer aPlayer;
- public initPlayer(EntityPlayer mPlayer) {
- this.aPlayer = mPlayer;
- }
- @Override
- public void run() {
- //Let us submit a doorknock to Segment to let them know who this is.
- submitInitData(aPlayer);
- }
- }
-
-}
diff --git a/src/Java/gtPlusPlus/api/analytics/SegmentHelper.java b/src/Java/gtPlusPlus/api/analytics/SegmentHelper.java
deleted file mode 100644
index 6e264fe1d2..0000000000
--- a/src/Java/gtPlusPlus/api/analytics/SegmentHelper.java
+++ /dev/null
@@ -1,81 +0,0 @@
-package gtPlusPlus.api.analytics;
-
-import com.segment.analytics.Analytics;
-import com.segment.analytics.Callback;
-import com.segment.analytics.messages.Message;
-import com.segment.analytics.messages.TrackMessage;
-import com.segment.analytics.messages.*;
-import java.util.Map;
-
-public class SegmentHelper implements Callback {
-
- /**
- * Credits to Author: FLAMINSAGANAKI/Theodore Mavrakis
- * http://domisydev.com/2015/11/05/using-segment-analytics-in-your-java-servlet/
- */
-
- private static final String writeKey = "EDOWl9peleGlUqe1ZwTqKDyuTMFhyT4k";
- private static volatile SegmentHelper segment = new SegmentHelper();
- private Analytics analytics;
-
- public SegmentHelper(){
- try{
- this.analytics = Analytics.builder(writeKey).callback(this).build();
- }catch(Exception e){
- SegmentAnalytics.LOG("exception while creating Analytics : " + e);
- }
- }
-
- public static SegmentHelper getInstance(){
- return segment;
- }
-
- public Analytics getAnalyticsClient(){
- return segment.analytics;
- }
-
- public void success(Message message) {
- SegmentAnalytics.LOG("Successfully uploaded " + message);
- }
-
- public void failure(Message message, Throwable throwable) {
- SegmentAnalytics.LOG("Could not upload " + message);
- }
-
- public void addUser(String user_id, Map<String, Object> properties) {
- try {
- this.analytics.enqueue(IdentifyMessage.builder().userId(user_id).traits(properties));
- //trackUser(user_id, "Logged In", properties);
- } catch (Exception e) {
- SegmentAnalytics.LOG("Exception in addUser() - " + e);
- }
- }
-
- public void trackUser(String user_id, String description, Map<String, Object> properties) {
- try {
- this.analytics.enqueue(TrackMessage.builder(description).userId(user_id).properties(properties));
- } catch (Exception e) {
- SegmentAnalytics.LOG("Exception in trackUser() - " + e);
- }
- }
-
- public void trackUser(String user_id, String description) {
- try {
- this.analytics.enqueue(TrackMessage.builder(description).userId(user_id));
- } catch (Exception e) {
- SegmentAnalytics.LOG("Exception in trackUser() - " + e);
- }
- }
-
- public void groupUser(String group_id, String user_id) {
- try {
- this.analytics.enqueue(GroupMessage.builder(group_id).userId(user_id));
- } catch (Exception e) {
- SegmentAnalytics.LOG("Exception in groupUser() - " + e);
- }
- }
-
- public static void main(String[] args){
-
- }
-} \ No newline at end of file
diff --git a/src/Java/gtPlusPlus/api/damage/BaseCustomDamageSource.java b/src/Java/gtPlusPlus/api/damage/BaseCustomDamageSource.java
deleted file mode 100644
index 24348988d6..0000000000
--- a/src/Java/gtPlusPlus/api/damage/BaseCustomDamageSource.java
+++ /dev/null
@@ -1,22 +0,0 @@
-package gtPlusPlus.api.damage;
-
-import net.minecraft.entity.Entity;
-import net.minecraft.util.EntityDamageSourceIndirect;
-
-public class BaseCustomDamageSource extends EntityDamageSourceIndirect {
-
- public BaseCustomDamageSource(String name, Entity transmitter, Entity indirectSource) {
- super(name, transmitter, indirectSource);
- this.setDifficultyScaled();
- }
-
- /**
- * Return whether this damage source will have its damage amount scaled based on the current difficulty.
- */
- public boolean isDifficultyScaled()
- {
- return true;
- }
-
-
-} \ No newline at end of file
diff --git a/src/Java/gtPlusPlus/api/damage/DamageTeslaTower.java b/src/Java/gtPlusPlus/api/damage/DamageTeslaTower.java
index ada2ba5c3d..f35c9cbc6b 100644
--- a/src/Java/gtPlusPlus/api/damage/DamageTeslaTower.java
+++ b/src/Java/gtPlusPlus/api/damage/DamageTeslaTower.java
@@ -5,6 +5,8 @@ import net.minecraft.entity.EntityLivingBase;
import net.minecraft.util.ChatComponentTranslation;
import net.minecraft.util.IChatComponent;
+import gtPlusPlus.core.world.damage.BaseCustomDamageSource;
+
public class DamageTeslaTower extends BaseCustomDamageSource{
public DamageTeslaTower(Entity transmitter) {
diff --git a/src/Java/gtPlusPlus/api/enums/Quality.java b/src/Java/gtPlusPlus/api/enums/Quality.java
new file mode 100644
index 0000000000..050f335b5e
--- /dev/null
+++ b/src/Java/gtPlusPlus/api/enums/Quality.java
@@ -0,0 +1,62 @@
+package gtPlusPlus.api.enums;
+
+import net.minecraft.util.EnumChatFormatting;
+
+import gtPlusPlus.core.util.math.MathUtils;
+
+public enum Quality {
+
+ // Magic Blue
+ // Rare Yellow
+ // Set Green
+ // Unique Gold/Purple
+ // Trade-off Brown
+
+ POOR("Poor", EnumChatFormatting.GRAY), COMMON("Common", EnumChatFormatting.WHITE), UNCOMMON("Uncommon",
+ EnumChatFormatting.DARK_GREEN), MAGIC("Magic", EnumChatFormatting.BLUE), RARE("Rare",
+ EnumChatFormatting.YELLOW), UNIQUE("Unique", EnumChatFormatting.GOLD), ARTIFACT("Artifact",
+ EnumChatFormatting.AQUA), SET("Set Piece", EnumChatFormatting.GREEN), TRADEOFF("Trade-off",
+ EnumChatFormatting.DARK_RED), EPIC("Epic", EnumChatFormatting.LIGHT_PURPLE);
+
+ private String LOOT;
+ private EnumChatFormatting COLOUR;
+
+ private Quality(final String lootTier, final EnumChatFormatting tooltipColour) {
+ this.LOOT = lootTier;
+ this.COLOUR = tooltipColour;
+ }
+
+ public String getQuality() {
+ return this.LOOT;
+ }
+
+ protected EnumChatFormatting getColour() {
+ return this.COLOUR;
+ }
+
+ public String formatted() {
+ return this.COLOUR + this.LOOT;
+ }
+
+ public static Quality getRandomQuality() {
+ final int lootChance = MathUtils.randInt(0, 100);
+ if (lootChance <= 10) {
+ return Quality.POOR;
+ } else if (lootChance <= 45) {
+ return Quality.COMMON;
+ } else if (lootChance <= 65) {
+ return Quality.UNCOMMON;
+ } else if (lootChance <= 82) {
+ return Quality.MAGIC;
+ } else if (lootChance <= 92) {
+ return Quality.EPIC;
+ } else if (lootChance <= 97) {
+ return Quality.RARE;
+ } else if (lootChance <= 99) {
+ return Quality.ARTIFACT;
+ } else {
+ return null;
+ }
+ }
+
+}
diff --git a/src/Java/gtPlusPlus/api/objects/MaterialHelper.java b/src/Java/gtPlusPlus/api/helpers/MaterialHelper.java
index d63ab7a15a..0acee40a0f 100644
--- a/src/Java/gtPlusPlus/api/objects/MaterialHelper.java
+++ b/src/Java/gtPlusPlus/api/helpers/MaterialHelper.java
@@ -1,10 +1,12 @@
-package gtPlusPlus.api.objects;
+package gtPlusPlus.api.helpers;
+
+import net.minecraft.item.ItemStack;
import gregtech.api.enums.Materials;
import gregtech.api.enums.OrePrefixes;
+
import gtPlusPlus.core.material.Material;
-import gtPlusPlus.core.util.item.ItemUtils;
-import net.minecraft.item.ItemStack;
+import gtPlusPlus.core.util.minecraft.ItemUtils;
public class MaterialHelper {
diff --git a/src/Java/gtPlusPlus/api/interfaces/IEntityCatcher.java b/src/Java/gtPlusPlus/api/interfaces/IEntityCatcher.java
index ca2d80de53..5ab90d47ce 100644
--- a/src/Java/gtPlusPlus/api/interfaces/IEntityCatcher.java
+++ b/src/Java/gtPlusPlus/api/interfaces/IEntityCatcher.java
@@ -1,10 +1,11 @@
package gtPlusPlus.api.interfaces;
-import gtPlusPlus.core.util.array.BlockPos;
import net.minecraft.entity.Entity;
import net.minecraft.item.ItemStack;
import net.minecraft.world.World;
+import gtPlusPlus.api.objects.minecraft.BlockPos;
+
public interface IEntityCatcher {
public boolean hasEntity(ItemStack aStack);
diff --git a/src/Java/gtPlusPlus/api/interfaces/IGregtechPower.java b/src/Java/gtPlusPlus/api/interfaces/IGregtechPower.java
new file mode 100644
index 0000000000..5f624e7a8c
--- /dev/null
+++ b/src/Java/gtPlusPlus/api/interfaces/IGregtechPower.java
@@ -0,0 +1,147 @@
+package gtPlusPlus.api.interfaces;
+
+import net.minecraft.block.Block;
+import net.minecraft.nbt.NBTTagCompound;
+import net.minecraft.tileentity.TileEntity;
+import net.minecraft.world.World;
+
+import gregtech.api.interfaces.IDescribable;
+import gregtech.api.interfaces.tileentity.*;
+
+import gtPlusPlus.core.tileentities.base.TilePoweredGT;
+
+public abstract interface IGregtechPower extends IGearEnergyTileEntity, ITurnable, IGregTechDeviceInformation, IDescribable, IBasicEnergyContainer {
+
+ @Override
+ public String[] getDescription();
+
+ @Override
+ default boolean isUniversalEnergyStored(long p0) {
+ return false;
+ }
+
+ @Override
+ public long getOutputAmperage();
+
+ @Override
+ public long getOutputVoltage();
+
+ @Override
+ public long getInputAmperage();
+
+ @Override
+ public long getInputVoltage();
+
+ @Override
+ public boolean decreaseStoredEnergyUnits(long p0, boolean p1);
+
+ @Override
+ public boolean increaseStoredEnergyUnits(long p0, boolean p1);
+
+ @Override
+ public boolean drainEnergyUnits(byte p0, long p1, long p2);
+
+ @Override
+ public long getAverageElectricInput();
+
+ @Override
+ public long getAverageElectricOutput();
+
+ @Override
+ public long getStoredEU();
+
+ @Override
+ public long getEUCapacity();
+
+ @Override
+ public long getStoredSteam();
+
+ @Override
+ public long getSteamCapacity();
+
+ @Override
+ public boolean increaseStoredSteam(long p0, boolean p1);
+
+ @Override
+ public Block getBlockAtSide(byte p0);
+
+ @Override
+ public Block getBlockAtSideAndDistance(byte p0, int p1);
+
+ @Override
+ public Block getBlockOffset(int p0, int p1, int p2);
+
+
+ @Override
+ public TileEntity getTileEntity(int p0, int p1, int p2);
+
+ @Override
+ public TileEntity getTileEntityAtSide(byte p0);
+
+ @Override
+ public TileEntity getTileEntityAtSideAndDistance(byte p0, int p1);
+
+ @Override
+ public TileEntity getTileEntityOffset(int p0, int p1, int p2);
+
+ @Override
+ public World getWorld();
+
+ @Override
+ public int getXCoord();
+
+ @Override
+ public short getYCoord();
+
+ @Override
+ public int getZCoord();
+
+ @Override
+ public boolean isClientSide();
+
+ @Override
+ public boolean isDead();
+
+ @Override
+ public boolean isInvalidTileEntity();
+
+ @Override
+ public boolean isServerSide();
+
+ @Override
+ public void readFromNBT(NBTTagCompound p0);
+
+ @Override
+ public void writeToNBT(NBTTagCompound p0);
+
+ @Override
+ public boolean acceptsRotationalEnergy(byte p0);
+
+ @Override
+ public boolean injectRotationalEnergy(byte p0, long p1, long p2);
+
+ @Override
+ public long injectEnergyUnits(byte p0, long p1, long p2);
+
+ @Override
+ public boolean inputEnergyFrom(byte p0);
+
+ @Override
+ public boolean outputsEnergyTo(byte p0);
+
+ @Override
+ public String[] getInfoData();
+
+ @Override
+ default public boolean isGivingInformation() {
+ return true;
+ }
+
+ boolean onPreTick(TilePoweredGT tilePoweredGT, long mTickTimer2);
+
+ boolean onTick(TilePoweredGT iGregTechTileEntity, long mTickTimer2);
+
+ boolean onPostTick(TilePoweredGT iGregTechTileEntity, long mTickTimer2);
+
+
+}
diff --git a/src/Java/gtPlusPlus/api/interfaces/IPlugin.java b/src/Java/gtPlusPlus/api/interfaces/IPlugin.java
index 3ac960eaf2..99c71a5823 100644
--- a/src/Java/gtPlusPlus/api/interfaces/IPlugin.java
+++ b/src/Java/gtPlusPlus/api/interfaces/IPlugin.java
@@ -1,12 +1,6 @@
package gtPlusPlus.api.interfaces;
-import gtPlusPlus.plugin.manager.Core_Manager;
-
public interface IPlugin {
-
- public default void register() {
- Core_Manager.registerPlugin(this);
- }
public String getPluginName();
diff --git a/src/Java/gtPlusPlus/api/interfaces/ITexturedBlock.java b/src/Java/gtPlusPlus/api/interfaces/ITexturedBlock.java
index 3a4b8f188c..47e692bffb 100644
--- a/src/Java/gtPlusPlus/api/interfaces/ITexturedBlock.java
+++ b/src/Java/gtPlusPlus/api/interfaces/ITexturedBlock.java
@@ -1,8 +1,9 @@
package gtPlusPlus.api.interfaces;
+import net.minecraft.block.Block;
+
import gregtech.api.interfaces.ITexture;
import gregtech.api.interfaces.tileentity.ITexturedTileEntity;
-import net.minecraft.block.Block;
public interface ITexturedBlock extends ITexturedTileEntity{
diff --git a/src/Java/gtPlusPlus/api/objects/Logger.java b/src/Java/gtPlusPlus/api/objects/Logger.java
index 1ecdaa9e86..2c50f0c15e 100644
--- a/src/Java/gtPlusPlus/api/objects/Logger.java
+++ b/src/Java/gtPlusPlus/api/objects/Logger.java
@@ -4,6 +4,7 @@ import org.apache.logging.log4j.LogManager;
import cpw.mods.fml.common.FMLLog;
import cpw.mods.fml.relauncher.FMLRelaunchLog;
+
import gtPlusPlus.core.lib.CORE;
import gtPlusPlus.core.proxy.ClientProxy;
diff --git a/src/Java/gtPlusPlus/api/objects/data/AutoMap.java b/src/Java/gtPlusPlus/api/objects/data/AutoMap.java
new file mode 100644
index 0000000000..e5b5ded0ad
--- /dev/null
+++ b/src/Java/gtPlusPlus/api/objects/data/AutoMap.java
@@ -0,0 +1,84 @@
+package gtPlusPlus.api.objects.data;
+
+import java.io.Serializable;
+import java.util.*;
+
+public class AutoMap<V> implements Iterable<V>, Cloneable, Serializable {
+
+ /**
+ * The Internal Map
+ */
+ private Map<Integer, V> mInternalMap = new HashMap<Integer, V>();
+