Storing Data Globally
In certain cases (e.g. in a cache that holds all currently loaded instances of a machine), you might need to store data in a global (static and mutable) variable.
When doing so, you need to ensure that remote and serverside instances don't get mixed up.
Using SideLocal<T>
Not yet merged
Branch: mi-ender-link
To make working with this requirement easier, You can use SideLocal<T>
to store your global data.
It is similar to Java's ThreadLocal
, but operates on the game's sides instead.
If you are currently on the remote side (GTCEuAPI.isClientThread()
/ on the client's main
thread), it will return the
remote side's instance of your data. Otherwise, you will get the server side's instance.
Example Usage
public class MyCache {
private static SideLocal<Map<UUID, MyData>> cache = new SideLocal<>(HashMap::new);
public static void cacheData(UUID id, MyData data) {
cache.get().put(id, data);
}
public static MyData getData(UUID id) {
return cache.get().get(id);
}
}
Alternatively to passing an initializer for both instances to SideLocal
's constructor, you can also supply
separate instances for the remote and server side.