mirror of
https://github.com/VolmitSoftware/Iris.git
synced 2025-07-18 10:12:53 +00:00
Auto stash before revert of "Drop it "
This commit is contained in:
parent
3ba7c18288
commit
f9e934fa1a
@ -26,10 +26,7 @@ import com.volmit.iris.core.link.MythicMobsLink;
|
|||||||
import com.volmit.iris.core.link.OraxenLink;
|
import com.volmit.iris.core.link.OraxenLink;
|
||||||
import com.volmit.iris.core.loader.IrisData;
|
import com.volmit.iris.core.loader.IrisData;
|
||||||
import com.volmit.iris.core.nms.INMS;
|
import com.volmit.iris.core.nms.INMS;
|
||||||
import com.volmit.iris.core.service.PreservationSVC;
|
|
||||||
import com.volmit.iris.core.service.StudioSVC;
|
import com.volmit.iris.core.service.StudioSVC;
|
||||||
import com.volmit.iris.engine.object.IrisBiome;
|
|
||||||
import com.volmit.iris.engine.object.IrisBiomeCustom;
|
|
||||||
import com.volmit.iris.engine.object.IrisCompat;
|
import com.volmit.iris.engine.object.IrisCompat;
|
||||||
import com.volmit.iris.engine.object.IrisDimension;
|
import com.volmit.iris.engine.object.IrisDimension;
|
||||||
import com.volmit.iris.engine.object.IrisWorld;
|
import com.volmit.iris.engine.object.IrisWorld;
|
||||||
@ -37,10 +34,10 @@ import com.volmit.iris.engine.platform.BukkitChunkGenerator;
|
|||||||
import com.volmit.iris.engine.platform.DummyChunkGenerator;
|
import com.volmit.iris.engine.platform.DummyChunkGenerator;
|
||||||
import com.volmit.iris.util.collection.KList;
|
import com.volmit.iris.util.collection.KList;
|
||||||
import com.volmit.iris.util.collection.KMap;
|
import com.volmit.iris.util.collection.KMap;
|
||||||
import com.volmit.iris.util.collection.KSet;
|
|
||||||
import com.volmit.iris.util.exceptions.IrisException;
|
import com.volmit.iris.util.exceptions.IrisException;
|
||||||
import com.volmit.iris.util.format.C;
|
import com.volmit.iris.util.format.C;
|
||||||
import com.volmit.iris.util.format.Form;
|
import com.volmit.iris.util.format.Form;
|
||||||
|
import com.volmit.iris.util.format.MemoryMonitor;
|
||||||
import com.volmit.iris.util.function.NastyRunnable;
|
import com.volmit.iris.util.function.NastyRunnable;
|
||||||
import com.volmit.iris.util.io.FileWatcher;
|
import com.volmit.iris.util.io.FileWatcher;
|
||||||
import com.volmit.iris.util.io.IO;
|
import com.volmit.iris.util.io.IO;
|
||||||
@ -48,7 +45,6 @@ import com.volmit.iris.util.io.InstanceState;
|
|||||||
import com.volmit.iris.util.io.JarScanner;
|
import com.volmit.iris.util.io.JarScanner;
|
||||||
import com.volmit.iris.util.math.M;
|
import com.volmit.iris.util.math.M;
|
||||||
import com.volmit.iris.util.math.RNG;
|
import com.volmit.iris.util.math.RNG;
|
||||||
import com.volmit.iris.util.matter.MatterTest;
|
|
||||||
import com.volmit.iris.util.parallel.MultiBurst;
|
import com.volmit.iris.util.parallel.MultiBurst;
|
||||||
import com.volmit.iris.util.plugin.IrisService;
|
import com.volmit.iris.util.plugin.IrisService;
|
||||||
import com.volmit.iris.util.plugin.Metrics;
|
import com.volmit.iris.util.plugin.Metrics;
|
||||||
|
@ -25,12 +25,15 @@ import com.volmit.iris.core.pregenerator.PregenListener;
|
|||||||
import com.volmit.iris.core.pregenerator.PregenTask;
|
import com.volmit.iris.core.pregenerator.PregenTask;
|
||||||
import com.volmit.iris.core.pregenerator.PregeneratorMethod;
|
import com.volmit.iris.core.pregenerator.PregeneratorMethod;
|
||||||
import com.volmit.iris.engine.data.cache.Cache;
|
import com.volmit.iris.engine.data.cache.Cache;
|
||||||
|
import com.volmit.iris.engine.framework.Engine;
|
||||||
import com.volmit.iris.util.collection.KList;
|
import com.volmit.iris.util.collection.KList;
|
||||||
import com.volmit.iris.util.format.Form;
|
import com.volmit.iris.util.format.Form;
|
||||||
|
import com.volmit.iris.util.format.MemoryMonitor;
|
||||||
import com.volmit.iris.util.function.Consumer2;
|
import com.volmit.iris.util.function.Consumer2;
|
||||||
import com.volmit.iris.util.mantle.Mantle;
|
import com.volmit.iris.util.mantle.Mantle;
|
||||||
import com.volmit.iris.util.math.M;
|
import com.volmit.iris.util.math.M;
|
||||||
import com.volmit.iris.util.math.Position2;
|
import com.volmit.iris.util.math.Position2;
|
||||||
|
import com.volmit.iris.util.scheduling.ChronoLatch;
|
||||||
import com.volmit.iris.util.scheduling.J;
|
import com.volmit.iris.util.scheduling.J;
|
||||||
import com.volmit.iris.util.scheduling.Looper;
|
import com.volmit.iris.util.scheduling.Looper;
|
||||||
|
|
||||||
@ -44,6 +47,7 @@ import java.awt.event.KeyEvent;
|
|||||||
import java.awt.event.KeyListener;
|
import java.awt.event.KeyListener;
|
||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
@ -51,11 +55,13 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
private static final Color COLOR_EXISTS = parseColor("#4d7d5b");
|
private static final Color COLOR_EXISTS = parseColor("#4d7d5b");
|
||||||
private static final Color COLOR_BLACK = parseColor("#4d7d5b");
|
private static final Color COLOR_BLACK = parseColor("#4d7d5b");
|
||||||
private static final Color COLOR_MANTLE = parseColor("#3c2773");
|
private static final Color COLOR_MANTLE = parseColor("#3c2773");
|
||||||
private static final Color COLOR_GENERATING = parseColor("#0062ff");
|
private static final Color COLOR_GENERATING = parseColor("#66967f");
|
||||||
private static final Color COLOR_NETWORK = parseColor("#a863c2");
|
private static final Color COLOR_NETWORK = parseColor("#a863c2");
|
||||||
private static final Color COLOR_NETWORK_GENERATING = parseColor("#836b8c");
|
private static final Color COLOR_NETWORK_GENERATING = parseColor("#836b8c");
|
||||||
private static final Color COLOR_GENERATED = parseColor("#34eb93");
|
private static final Color COLOR_GENERATED = parseColor("#65c295");
|
||||||
|
private static final Color COLOR_CLEANED = parseColor("#34eb93");
|
||||||
public static PregeneratorJob instance;
|
public static PregeneratorJob instance;
|
||||||
|
private final MemoryMonitor monitor;
|
||||||
private final PregenTask task;
|
private final PregenTask task;
|
||||||
private final boolean saving;
|
private final boolean saving;
|
||||||
private final KList<Consumer<Double>> onProgress = new KList<>();
|
private final KList<Consumer<Double>> onProgress = new KList<>();
|
||||||
@ -65,10 +71,15 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
private final Position2 max;
|
private final Position2 max;
|
||||||
private JFrame frame;
|
private JFrame frame;
|
||||||
private PregenRenderer renderer;
|
private PregenRenderer renderer;
|
||||||
|
private int rgc = 0;
|
||||||
|
private ChronoLatch cl = new ChronoLatch(TimeUnit.MINUTES.toMillis(1));
|
||||||
private String[] info;
|
private String[] info;
|
||||||
|
private Engine engine;
|
||||||
|
|
||||||
public PregeneratorJob(PregenTask task, PregeneratorMethod method) {
|
public PregeneratorJob(PregenTask task, PregeneratorMethod method, Engine engine) {
|
||||||
|
this.engine = engine;
|
||||||
instance = this;
|
instance = this;
|
||||||
|
monitor = new MemoryMonitor(50);
|
||||||
saving = false;
|
saving = false;
|
||||||
info = new String[]{"Initializing..."};
|
info = new String[]{"Initializing..."};
|
||||||
this.task = task;
|
this.task = task;
|
||||||
@ -181,6 +192,7 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
public void close() {
|
public void close() {
|
||||||
J.a(() -> {
|
J.a(() -> {
|
||||||
try {
|
try {
|
||||||
|
monitor.close();
|
||||||
J.sleep(3000);
|
J.sleep(3000);
|
||||||
frame.setVisible(false);
|
frame.setVisible(false);
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
@ -220,6 +232,8 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
"Speed: " + Form.f(chunksPerSecond, 0) + " Chunks/s, " + Form.f(regionsPerMinute, 1) + " Regions/m, " + Form.f(chunksPerMinute, 0) + " Chunks/m",
|
"Speed: " + Form.f(chunksPerSecond, 0) + " Chunks/s, " + Form.f(regionsPerMinute, 1) + " Regions/m, " + Form.f(chunksPerMinute, 0) + " Chunks/m",
|
||||||
Form.duration(eta, 2) + " Remaining " + " (" + Form.duration(elapsed, 2) + " Elapsed)",
|
Form.duration(eta, 2) + " Remaining " + " (" + Form.duration(elapsed, 2) + " Elapsed)",
|
||||||
"Generation Method: " + method,
|
"Generation Method: " + method,
|
||||||
|
"Memory: " + Form.memSize(monitor.getUsedBytes(), 2) + " (" + Form.pc(monitor.getUsagePercent(), 0) + ") Pressure: " + Form.memSize(monitor.getPressure(), 0) + "/s",
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
for (Consumer<Double> i : onProgress) {
|
for (Consumer<Double> i : onProgress) {
|
||||||
@ -229,17 +243,36 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChunkGenerating(int x, int z) {
|
public void onChunkGenerating(int x, int z) {
|
||||||
|
if(engine != null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
draw(x, z, COLOR_GENERATING);
|
draw(x, z, COLOR_GENERATING);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChunkGenerated(int x, int z) {
|
public void onChunkGenerated(int x, int z) {
|
||||||
|
if(engine != null)
|
||||||
|
{
|
||||||
|
draw(x, z, engine.draw((x << 4) + 8, (z << 4) + 8));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
draw(x, z, COLOR_GENERATED);
|
draw(x, z, COLOR_GENERATED);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRegionGenerated(int x, int z) {
|
public void onRegionGenerated(int x, int z) {
|
||||||
|
shouldGc();
|
||||||
|
rgc++;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void shouldGc() {
|
||||||
|
if(cl.flip() && rgc > 16)
|
||||||
|
{
|
||||||
|
System.gc();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -247,6 +280,11 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChunkCleaned(int x, int z) {
|
||||||
|
//draw(x, z, COLOR_CLEANED);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRegionSkipped(int x, int z) {
|
public void onRegionSkipped(int x, int z) {
|
||||||
|
|
||||||
@ -291,6 +329,12 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChunkExistsInRegionGen(int x, int z) {
|
public void onChunkExistsInRegionGen(int x, int z) {
|
||||||
|
if(engine != null)
|
||||||
|
{
|
||||||
|
draw(x, z, engine.draw((x << 4) + 8, (z << 4) + 8));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
draw(x, z, COLOR_EXISTS);
|
draw(x, z, COLOR_EXISTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -347,7 +391,7 @@ public class PregeneratorJob implements PregenListener {
|
|||||||
l.unlock();
|
l.unlock();
|
||||||
g.drawImage(image, 0, 0, getParent().getWidth(), getParent().getHeight(), (img, infoflags, x, y, width, height) -> true);
|
g.drawImage(image, 0, 0, getParent().getWidth(), getParent().getHeight(), (img, infoflags, x, y, width, height) -> true);
|
||||||
g.setColor(Color.WHITE);
|
g.setColor(Color.WHITE);
|
||||||
g.setFont(new Font("Hevetica", Font.BOLD, 28));
|
g.setFont(new Font("Hevetica", Font.BOLD, 13));
|
||||||
String[] prog = job.getProgress();
|
String[] prog = job.getProgress();
|
||||||
int h = g.getFontMetrics().getHeight() + 5;
|
int h = g.getFontMetrics().getHeight() + 5;
|
||||||
int hh = 20;
|
int hh = 20;
|
||||||
|
@ -223,6 +223,11 @@ public class IrisPregenerator {
|
|||||||
listener.onRegionGenerating(x, z);
|
listener.onRegionGenerating(x, z);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChunkCleaned(int x, int z) {
|
||||||
|
listener.onChunkCleaned(x, z);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRegionSkipped(int x, int z) {
|
public void onRegionSkipped(int x, int z) {
|
||||||
listener.onRegionSkipped(x, z);
|
listener.onRegionSkipped(x, z);
|
||||||
|
@ -29,6 +29,8 @@ public interface PregenListener {
|
|||||||
|
|
||||||
void onRegionGenerating(int x, int z);
|
void onRegionGenerating(int x, int z);
|
||||||
|
|
||||||
|
void onChunkCleaned(int x, int z);
|
||||||
|
|
||||||
void onRegionSkipped(int x, int z);
|
void onRegionSkipped(int x, int z);
|
||||||
|
|
||||||
void onNetworkStarted(int x, int z);
|
void onNetworkStarted(int x, int z);
|
||||||
|
@ -18,20 +18,30 @@
|
|||||||
|
|
||||||
package com.volmit.iris.core.pregenerator;
|
package com.volmit.iris.core.pregenerator;
|
||||||
|
|
||||||
|
import com.volmit.iris.Iris;
|
||||||
import com.volmit.iris.util.collection.KList;
|
import com.volmit.iris.util.collection.KList;
|
||||||
import com.volmit.iris.util.mantle.Mantle;
|
import com.volmit.iris.util.collection.KMap;
|
||||||
|
import com.volmit.iris.util.collection.KSet;
|
||||||
import com.volmit.iris.util.math.Position2;
|
import com.volmit.iris.util.math.Position2;
|
||||||
|
import com.volmit.iris.util.math.RNG;
|
||||||
import com.volmit.iris.util.math.Spiraled;
|
import com.volmit.iris.util.math.Spiraled;
|
||||||
import com.volmit.iris.util.math.Spiraler;
|
import com.volmit.iris.util.math.Spiraler;
|
||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
import org.checkerframework.checker.units.qual.K;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
@Builder
|
@Builder
|
||||||
@Data
|
@Data
|
||||||
public class PregenTask {
|
public class PregenTask {
|
||||||
private static final KList<Position2> order = computeChunkOrder();
|
private static final Position2 ZERO = new Position2(0,0);
|
||||||
|
private static final KList<Position2> ORDER_CENTER = computeChunkOrder();
|
||||||
|
private static final KMap<Position2, KList<Position2>> ORDERS = new KMap<>();
|
||||||
|
|
||||||
@Builder.Default
|
@Builder.Default
|
||||||
private Position2 center = new Position2(0, 0);
|
private Position2 center = new Position2(0, 0);
|
||||||
@Builder.Default
|
@Builder.Default
|
||||||
@ -39,12 +49,46 @@ public class PregenTask {
|
|||||||
@Builder.Default
|
@Builder.Default
|
||||||
private int height = 1;
|
private int height = 1;
|
||||||
|
|
||||||
public static void iterateRegion(int xr, int zr, Spiraled s) {
|
public static void iterateRegion(int xr, int zr, Spiraled s, Position2 pull) {
|
||||||
for (Position2 i : order) {
|
for (Position2 i : ORDERS.computeIfAbsent(pull, PregenTask::computeOrder)) {
|
||||||
s.on(i.getX() + (xr << 5), i.getZ() + (zr << 5));
|
s.on(i.getX() + (xr << 5), i.getZ() + (zr << 5));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void iterateRegion(int xr, int zr, Spiraled s) {
|
||||||
|
iterateRegion(xr, zr, s, new Position2(0,0));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Position2 avg(Position2... c)
|
||||||
|
{
|
||||||
|
double x = 0;
|
||||||
|
double z = 0;
|
||||||
|
|
||||||
|
for(Position2 i : c)
|
||||||
|
{
|
||||||
|
x += i.getX() * 15;
|
||||||
|
z += i.getZ() * 15;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Position2((int)(x / c.length), (int)(z / c.length));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static KList<Position2> computeOrder(Position2 pull) {
|
||||||
|
KList<Position2> p = new KList<>();
|
||||||
|
new Spiraler(33, 33, (x, z) -> {
|
||||||
|
int xx = (x + 15);
|
||||||
|
int zz = (z + 15);
|
||||||
|
if (xx < 0 || xx > 31 || zz < 0 || zz > 31) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.add(new Position2(xx, zz));
|
||||||
|
}).drain();
|
||||||
|
p.sort(Comparator.comparing((i) -> i.distance(pull)));
|
||||||
|
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
private static KList<Position2> computeChunkOrder() {
|
private static KList<Position2> computeChunkOrder() {
|
||||||
Position2 center = new Position2(15, 15);
|
Position2 center = new Position2(15, 15);
|
||||||
KList<Position2> p = new KList<>();
|
KList<Position2> p = new KList<>();
|
||||||
|
@ -70,6 +70,7 @@ public class AsyncPregenMethod implements PregeneratorMethod {
|
|||||||
try {
|
try {
|
||||||
PaperLib.getChunkAtAsync(world, x, z, true).get();
|
PaperLib.getChunkAtAsync(world, x, z, true).get();
|
||||||
listener.onChunkGenerated(x, z);
|
listener.onChunkGenerated(x, z);
|
||||||
|
listener.onChunkCleaned(x, z);
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
J.sleep(5);
|
J.sleep(5);
|
||||||
|
@ -105,6 +105,7 @@ public class MedievalPregenMethod implements PregeneratorMethod {
|
|||||||
futures.add(J.sfut(() -> {
|
futures.add(J.sfut(() -> {
|
||||||
world.getChunkAt(x, z);
|
world.getChunkAt(x, z);
|
||||||
listener.onChunkGenerated(x, z);
|
listener.onChunkGenerated(x, z);
|
||||||
|
listener.onChunkCleaned(x, z);
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,6 +212,11 @@ public class SyndicateServer extends Thread implements PregenListener {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChunkCleaned(int x, int z) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRegionSkipped(int x, int z) {
|
public void onRegionSkipped(int x, int z) {
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ import com.volmit.iris.core.pregenerator.PregeneratorMethod;
|
|||||||
import com.volmit.iris.core.pregenerator.methods.HeadlessPregenMethod;
|
import com.volmit.iris.core.pregenerator.methods.HeadlessPregenMethod;
|
||||||
import com.volmit.iris.core.pregenerator.methods.HybridPregenMethod;
|
import com.volmit.iris.core.pregenerator.methods.HybridPregenMethod;
|
||||||
import com.volmit.iris.core.service.StudioSVC;
|
import com.volmit.iris.core.service.StudioSVC;
|
||||||
|
import com.volmit.iris.engine.framework.Engine;
|
||||||
import com.volmit.iris.engine.object.IrisDimension;
|
import com.volmit.iris.engine.object.IrisDimension;
|
||||||
import com.volmit.iris.engine.platform.HeadlessGenerator;
|
import com.volmit.iris.engine.platform.HeadlessGenerator;
|
||||||
import com.volmit.iris.engine.platform.PlatformChunkGenerator;
|
import com.volmit.iris.engine.platform.PlatformChunkGenerator;
|
||||||
@ -120,8 +121,8 @@ public class IrisToolbelt {
|
|||||||
* @param method the method to execute the task
|
* @param method the method to execute the task
|
||||||
* @return the pregenerator job (already started)
|
* @return the pregenerator job (already started)
|
||||||
*/
|
*/
|
||||||
public static PregeneratorJob pregenerate(PregenTask task, PregeneratorMethod method) {
|
public static PregeneratorJob pregenerate(PregenTask task, PregeneratorMethod method, Engine engine) {
|
||||||
return new PregeneratorJob(task, method);
|
return new PregeneratorJob(task, method, engine);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -134,11 +135,11 @@ public class IrisToolbelt {
|
|||||||
*/
|
*/
|
||||||
public static PregeneratorJob pregenerate(PregenTask task, PlatformChunkGenerator gen) {
|
public static PregeneratorJob pregenerate(PregenTask task, PlatformChunkGenerator gen) {
|
||||||
if (gen.isHeadless()) {
|
if (gen.isHeadless()) {
|
||||||
return pregenerate(task, new HeadlessPregenMethod(((HeadlessGenerator) gen).getWorld(), (HeadlessGenerator) gen));
|
return pregenerate(task, new HeadlessPregenMethod(((HeadlessGenerator) gen).getWorld(), (HeadlessGenerator) gen), gen.getEngine());
|
||||||
}
|
}
|
||||||
|
|
||||||
return pregenerate(task, new HybridPregenMethod(gen.getEngine().getWorld().realWorld(),
|
return pregenerate(task, new HybridPregenMethod(gen.getEngine().getWorld().realWorld(),
|
||||||
IrisSettings.getThreadCount(IrisSettings.get().getConcurrency().getParallelism())));
|
IrisSettings.getThreadCount(IrisSettings.get().getConcurrency().getParallelism())), gen.getEngine());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -154,7 +155,7 @@ public class IrisToolbelt {
|
|||||||
return pregenerate(task, access(world));
|
return pregenerate(task, access(world));
|
||||||
}
|
}
|
||||||
|
|
||||||
return pregenerate(task, new HybridPregenMethod(world, IrisSettings.getThreadCount(IrisSettings.get().getConcurrency().getParallelism())));
|
return pregenerate(task, new HybridPregenMethod(world, IrisSettings.getThreadCount(IrisSettings.get().getConcurrency().getParallelism())), null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
package com.volmit.iris.engine;
|
package com.volmit.iris.engine;
|
||||||
|
|
||||||
import com.volmit.iris.Iris;
|
import com.volmit.iris.Iris;
|
||||||
|
import com.volmit.iris.core.IrisSettings;
|
||||||
import com.volmit.iris.engine.data.cache.Cache;
|
import com.volmit.iris.engine.data.cache.Cache;
|
||||||
import com.volmit.iris.engine.framework.Engine;
|
import com.volmit.iris.engine.framework.Engine;
|
||||||
import com.volmit.iris.engine.framework.EngineAssignedWorldManager;
|
import com.volmit.iris.engine.framework.EngineAssignedWorldManager;
|
||||||
@ -41,6 +42,8 @@ import com.volmit.iris.util.mantle.Mantle;
|
|||||||
import com.volmit.iris.util.mantle.MantleFlag;
|
import com.volmit.iris.util.mantle.MantleFlag;
|
||||||
import com.volmit.iris.util.math.M;
|
import com.volmit.iris.util.math.M;
|
||||||
import com.volmit.iris.util.math.RNG;
|
import com.volmit.iris.util.math.RNG;
|
||||||
|
import com.volmit.iris.util.matter.MatterCavern;
|
||||||
|
import com.volmit.iris.util.matter.MatterFluidBody;
|
||||||
import com.volmit.iris.util.matter.MatterMarker;
|
import com.volmit.iris.util.matter.MatterMarker;
|
||||||
import com.volmit.iris.util.plugin.Chunks;
|
import com.volmit.iris.util.plugin.Chunks;
|
||||||
import com.volmit.iris.util.scheduling.ChronoLatch;
|
import com.volmit.iris.util.scheduling.ChronoLatch;
|
||||||
@ -49,6 +52,7 @@ import com.volmit.iris.util.scheduling.Looper;
|
|||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import org.bukkit.Chunk;
|
import org.bukkit.Chunk;
|
||||||
|
import org.bukkit.block.data.BlockData;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.LivingEntity;
|
import org.bukkit.entity.LivingEntity;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -460,6 +464,7 @@ public class IrisWorldManager extends EngineAssignedWorldManager {
|
|||||||
public void onChunkLoad(Chunk e, boolean generated) {
|
public void onChunkLoad(Chunk e, boolean generated) {
|
||||||
energy += 0.3;
|
energy += 0.3;
|
||||||
fixEnergy();
|
fixEnergy();
|
||||||
|
getEngine().cleanupMantleChunk(e.getX(), e.getZ());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void spawn(IrisPosition block, IrisSpawner spawner, boolean initial) {
|
private void spawn(IrisPosition block, IrisSpawner spawner, boolean initial) {
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
package com.volmit.iris.engine.framework;
|
package com.volmit.iris.engine.framework;
|
||||||
|
|
||||||
import com.volmit.iris.Iris;
|
import com.volmit.iris.Iris;
|
||||||
|
import com.volmit.iris.core.IrisSettings;
|
||||||
import com.volmit.iris.core.gui.components.RenderType;
|
import com.volmit.iris.core.gui.components.RenderType;
|
||||||
import com.volmit.iris.core.gui.components.Renderer;
|
import com.volmit.iris.core.gui.components.Renderer;
|
||||||
import com.volmit.iris.core.loader.IrisData;
|
import com.volmit.iris.core.loader.IrisData;
|
||||||
@ -60,6 +61,7 @@ import com.volmit.iris.util.math.M;
|
|||||||
import com.volmit.iris.util.math.Position2;
|
import com.volmit.iris.util.math.Position2;
|
||||||
import com.volmit.iris.util.math.RNG;
|
import com.volmit.iris.util.math.RNG;
|
||||||
import com.volmit.iris.util.matter.MatterCavern;
|
import com.volmit.iris.util.matter.MatterCavern;
|
||||||
|
import com.volmit.iris.util.matter.MatterFluidBody;
|
||||||
import com.volmit.iris.util.matter.MatterUpdate;
|
import com.volmit.iris.util.matter.MatterUpdate;
|
||||||
import com.volmit.iris.util.parallel.BurstExecutor;
|
import com.volmit.iris.util.parallel.BurstExecutor;
|
||||||
import com.volmit.iris.util.parallel.MultiBurst;
|
import com.volmit.iris.util.parallel.MultiBurst;
|
||||||
@ -902,4 +904,12 @@ public interface Engine extends DataProvider, Fallible, LootProvider, BlockUpdat
|
|||||||
|
|
||||||
Locator.region(r.getLoadKey()).find(player);
|
Locator.region(r.getLoadKey()).find(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
default void cleanupMantleChunk(int x, int z)
|
||||||
|
{
|
||||||
|
if(IrisSettings.get().getPerformance().isTrimMantleInStudio() || !isStudio())
|
||||||
|
{
|
||||||
|
J.a(() -> getMantle().cleanupChunk(x, z));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
package com.volmit.iris.engine.mantle;
|
package com.volmit.iris.engine.mantle;
|
||||||
|
|
||||||
|
import com.volmit.iris.Iris;
|
||||||
import com.volmit.iris.core.IrisSettings;
|
import com.volmit.iris.core.IrisSettings;
|
||||||
import com.volmit.iris.core.loader.IrisData;
|
import com.volmit.iris.core.loader.IrisData;
|
||||||
import com.volmit.iris.engine.IrisComplex;
|
import com.volmit.iris.engine.IrisComplex;
|
||||||
@ -40,13 +41,17 @@ import com.volmit.iris.util.mantle.MantleChunk;
|
|||||||
import com.volmit.iris.util.mantle.MantleFlag;
|
import com.volmit.iris.util.mantle.MantleFlag;
|
||||||
import com.volmit.iris.util.matter.Matter;
|
import com.volmit.iris.util.matter.Matter;
|
||||||
import com.volmit.iris.util.matter.MatterCavern;
|
import com.volmit.iris.util.matter.MatterCavern;
|
||||||
|
import com.volmit.iris.util.matter.MatterFluidBody;
|
||||||
import com.volmit.iris.util.matter.MatterMarker;
|
import com.volmit.iris.util.matter.MatterMarker;
|
||||||
import com.volmit.iris.util.matter.slices.UpdateMatter;
|
import com.volmit.iris.util.matter.slices.UpdateMatter;
|
||||||
import com.volmit.iris.util.parallel.BurstExecutor;
|
import com.volmit.iris.util.parallel.BurstExecutor;
|
||||||
import com.volmit.iris.util.parallel.MultiBurst;
|
import com.volmit.iris.util.parallel.MultiBurst;
|
||||||
|
import com.volmit.iris.util.scheduling.J;
|
||||||
|
import io.papermc.lib.PaperLib;
|
||||||
import org.bukkit.block.TileState;
|
import org.bukkit.block.TileState;
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
|
|
||||||
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
// TODO: MOVE PLACER OUT OF MATTER INTO ITS OWN THING
|
// TODO: MOVE PLACER OUT OF MATTER INTO ITS OWN THING
|
||||||
@ -207,11 +212,13 @@ public interface EngineMantle extends IObjectPlacer {
|
|||||||
int zz = j + z;
|
int zz = j + z;
|
||||||
burst.queue(() -> {
|
burst.queue(() -> {
|
||||||
IrisContext.touch(getEngine().getContext());
|
IrisContext.touch(getEngine().getContext());
|
||||||
MantleChunk mc = getMantle().getChunk(xx, zz);
|
getMantle().raiseFlag(xx, zz, MantleFlag.PLANNED, () -> {
|
||||||
|
MantleChunk mc = getMantle().getChunk(xx, zz);
|
||||||
|
|
||||||
for (MantleComponent k : getComponents()) {
|
for (MantleComponent k : getComponents()) {
|
||||||
generateMantleComponent(writer, xx, zz, k, mc);
|
generateMantleComponent(writer, xx, zz, k, mc);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -262,4 +269,35 @@ public interface EngineMantle extends IObjectPlacer {
|
|||||||
MantleJigsawComponent getJigsawComponent();
|
MantleJigsawComponent getJigsawComponent();
|
||||||
|
|
||||||
MantleObjectComponent getObjectComponent();
|
MantleObjectComponent getObjectComponent();
|
||||||
|
|
||||||
|
default boolean isCovered(int x, int z)
|
||||||
|
{
|
||||||
|
int s = getRealRadius();
|
||||||
|
|
||||||
|
for (int i = -s; i <= s; i++) {
|
||||||
|
for (int j = -s; j <= s; j++) {
|
||||||
|
int xx = i + x;
|
||||||
|
int zz = j + z;
|
||||||
|
if(!getMantle().hasFlag(xx, zz, MantleFlag.PLANNED))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
default void cleanupChunk(int x, int z)
|
||||||
|
{
|
||||||
|
if(!getMantle().hasFlag(x, z, MantleFlag.CLEANED) && isCovered(x, z))
|
||||||
|
{
|
||||||
|
getMantle().raiseFlag(x, z, MantleFlag.CLEANED, () -> {
|
||||||
|
getMantle().deleteChunkSlice(x, z, BlockData.class);
|
||||||
|
getMantle().deleteChunkSlice(x, z, String.class);
|
||||||
|
getMantle().deleteChunkSlice(x, z, MatterCavern.class);
|
||||||
|
getMantle().deleteChunkSlice(x, z, MatterFluidBody.class);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,7 @@ import com.volmit.iris.engine.framework.Engine;
|
|||||||
import com.volmit.iris.engine.framework.EngineTarget;
|
import com.volmit.iris.engine.framework.EngineTarget;
|
||||||
import com.volmit.iris.engine.object.HeadlessWorld;
|
import com.volmit.iris.engine.object.HeadlessWorld;
|
||||||
import com.volmit.iris.util.collection.KList;
|
import com.volmit.iris.util.collection.KList;
|
||||||
|
import com.volmit.iris.util.collection.KSet;
|
||||||
import com.volmit.iris.util.documentation.ChunkCoordinates;
|
import com.volmit.iris.util.documentation.ChunkCoordinates;
|
||||||
import com.volmit.iris.util.documentation.RegionCoordinates;
|
import com.volmit.iris.util.documentation.RegionCoordinates;
|
||||||
import com.volmit.iris.util.hunk.Hunk;
|
import com.volmit.iris.util.hunk.Hunk;
|
||||||
@ -40,6 +41,7 @@ import com.volmit.iris.util.nbt.mca.NBTWorld;
|
|||||||
import com.volmit.iris.util.nbt.tag.CompoundTag;
|
import com.volmit.iris.util.nbt.tag.CompoundTag;
|
||||||
import com.volmit.iris.util.parallel.BurstExecutor;
|
import com.volmit.iris.util.parallel.BurstExecutor;
|
||||||
import com.volmit.iris.util.parallel.MultiBurst;
|
import com.volmit.iris.util.parallel.MultiBurst;
|
||||||
|
import com.volmit.iris.util.scheduling.J;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
@ -48,6 +50,8 @@ import org.bukkit.generator.ChunkGenerator;
|
|||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@ -59,6 +63,7 @@ public class HeadlessGenerator implements PlatformChunkGenerator {
|
|||||||
private final MultiBurst burst;
|
private final MultiBurst burst;
|
||||||
private final Engine engine;
|
private final Engine engine;
|
||||||
private final long rkey = RNG.r.lmax();
|
private final long rkey = RNG.r.lmax();
|
||||||
|
private List<Position2> last = new KList<>();
|
||||||
|
|
||||||
public HeadlessGenerator(HeadlessWorld world) {
|
public HeadlessGenerator(HeadlessWorld world) {
|
||||||
this(world, new IrisEngine(new EngineTarget(world.getWorld(), world.getDimension(), world.getDimension().getLoader()), world.isStudio()));
|
this(world, new IrisEngine(new EngineTarget(world.getWorld(), world.getDimension(), world.getDimension().getLoader()), world.isStudio()));
|
||||||
@ -124,9 +129,35 @@ public class HeadlessGenerator implements PlatformChunkGenerator {
|
|||||||
if (listener != null) {
|
if (listener != null) {
|
||||||
listener.onChunkGenerated(ii, jj);
|
listener.onChunkGenerated(ii, jj);
|
||||||
}
|
}
|
||||||
}));
|
}), avgLast(x, z));
|
||||||
|
last.add(new Position2(x, z));
|
||||||
|
|
||||||
e.complete();
|
e.complete();
|
||||||
|
|
||||||
|
J.a(() -> PregenTask.iterateRegion(x, z, (ii, jj) -> {
|
||||||
|
getEngine().cleanupMantleChunk(ii, jj);
|
||||||
|
if (listener != null) {
|
||||||
|
listener.onChunkCleaned(ii, jj);
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
private Position2 avgLast(int x, int z) {
|
||||||
|
while(last.size() > 3)
|
||||||
|
{
|
||||||
|
last.remove(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
double xx = 0;
|
||||||
|
double zz = 0;
|
||||||
|
|
||||||
|
for(Position2 i : last)
|
||||||
|
{
|
||||||
|
xx += 7 * (i.getX() - x);
|
||||||
|
zz += 7 * (i.getZ() - z);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Position2((int)xx, (int)zz);
|
||||||
}
|
}
|
||||||
|
|
||||||
@RegionCoordinates
|
@RegionCoordinates
|
||||||
|
147
src/main/java/com/volmit/iris/util/format/MemoryMonitor.java
Normal file
147
src/main/java/com/volmit/iris/util/format/MemoryMonitor.java
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
/*
|
||||||
|
* Iris is a World Generator for Minecraft Bukkit Servers
|
||||||
|
* Copyright (c) 2021 Arcane Arts (Volmit Software)
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.volmit.iris.util.format;
|
||||||
|
|
||||||
|
import com.volmit.iris.Iris;
|
||||||
|
import com.volmit.iris.util.math.RollingSequence;
|
||||||
|
import com.volmit.iris.util.scheduling.ChronoLatch;
|
||||||
|
import com.volmit.iris.util.scheduling.Looper;
|
||||||
|
|
||||||
|
public class MemoryMonitor {
|
||||||
|
private Looper looper;
|
||||||
|
private long usedMemory;
|
||||||
|
private long garbageMemory;
|
||||||
|
private long garbageLast;
|
||||||
|
private long garbageBin;
|
||||||
|
private long pressure;
|
||||||
|
private ChronoLatch cl;
|
||||||
|
private RollingSequence pressureAvg;
|
||||||
|
private Runtime runtime;
|
||||||
|
|
||||||
|
public MemoryMonitor(int sampleDelay){
|
||||||
|
this.runtime = Runtime.getRuntime();
|
||||||
|
usedMemory = -1;
|
||||||
|
pressureAvg = new RollingSequence(Math.max(Math.min(100, 1000/sampleDelay), 3));
|
||||||
|
garbageBin = 0;
|
||||||
|
garbageMemory = -1;
|
||||||
|
cl = new ChronoLatch(1000);
|
||||||
|
garbageLast = 0;
|
||||||
|
pressure = 0;
|
||||||
|
|
||||||
|
looper = new Looper() {
|
||||||
|
@Override
|
||||||
|
protected long loop() {
|
||||||
|
sample();
|
||||||
|
return sampleDelay;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
looper.setPriority(Thread.MIN_PRIORITY);
|
||||||
|
looper.setName("Memory Monitor");
|
||||||
|
looper.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getGarbageBytes()
|
||||||
|
{
|
||||||
|
return garbageMemory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getUsedBytes()
|
||||||
|
{
|
||||||
|
return usedMemory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getMaxBytes()
|
||||||
|
{
|
||||||
|
return runtime.maxMemory();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getPressure()
|
||||||
|
{
|
||||||
|
return (long) pressureAvg.getAverage();
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getUsagePercent()
|
||||||
|
{
|
||||||
|
return usedMemory / (double)getMaxBytes();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void sample() {
|
||||||
|
long used = getVMUse();
|
||||||
|
if(usedMemory == -1)
|
||||||
|
{
|
||||||
|
usedMemory = used;
|
||||||
|
garbageMemory = 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(used < usedMemory)
|
||||||
|
{
|
||||||
|
usedMemory = used;
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
garbageMemory = used - usedMemory;
|
||||||
|
}
|
||||||
|
|
||||||
|
long g = garbageMemory - garbageLast;
|
||||||
|
|
||||||
|
if(g >= 0)
|
||||||
|
{
|
||||||
|
garbageBin+= g;
|
||||||
|
garbageLast = garbageMemory;
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
garbageMemory = 0;
|
||||||
|
garbageLast = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(cl.flip())
|
||||||
|
{
|
||||||
|
if(garbageMemory > 0)
|
||||||
|
{
|
||||||
|
pressure = garbageBin;
|
||||||
|
garbageBin = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pressure = 0;
|
||||||
|
garbageBin = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pressureAvg.put(pressure);
|
||||||
|
}
|
||||||
|
|
||||||
|
private long getVMUse() {
|
||||||
|
return runtime.totalMemory() - runtime.freeMemory();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void close()
|
||||||
|
{
|
||||||
|
if(looper != null)
|
||||||
|
{
|
||||||
|
looper.interrupt();
|
||||||
|
looper = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -29,7 +29,9 @@ public enum MantleFlag {
|
|||||||
REAL,
|
REAL,
|
||||||
CARVED,
|
CARVED,
|
||||||
FLUID_BODIES,
|
FLUID_BODIES,
|
||||||
INITIAL_SPAWNED_MARKER;
|
INITIAL_SPAWNED_MARKER,
|
||||||
|
CLEANED,
|
||||||
|
PLANNED;
|
||||||
|
|
||||||
static StateList getStateList() {
|
static StateList getStateList() {
|
||||||
return new StateList(MantleFlag.values());
|
return new StateList(MantleFlag.values());
|
||||||
|
@ -152,7 +152,7 @@ public interface MatterSlice<T> extends Hunk<T>, PaletteType<T> {
|
|||||||
|
|
||||||
default void write(DataOutputStream dos) throws IOException {
|
default void write(DataOutputStream dos) throws IOException {
|
||||||
dos.writeUTF(getType().getCanonicalName());
|
dos.writeUTF(getType().getCanonicalName());
|
||||||
if(IrisSettings.get().getPerformance().isUseExperimentalMantleMemoryCompression() && (this instanceof PaletteOrHunk f && f.isPalette()))
|
if((this instanceof PaletteOrHunk f && f.isPalette()))
|
||||||
{
|
{
|
||||||
PalettedContainer<T> c = f.palette();
|
PalettedContainer<T> c = f.palette();
|
||||||
List<T> palette = new ArrayList<>();
|
List<T> palette = new ArrayList<>();
|
||||||
@ -192,7 +192,7 @@ public interface MatterSlice<T> extends Hunk<T>, PaletteType<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
default void read(DataInputStream din) throws IOException {
|
default void read(DataInputStream din) throws IOException {
|
||||||
if(IrisSettings.get().getPerformance().isUseExperimentalMantleMemoryCompression() && (this instanceof PaletteOrHunk f && f.isPalette()))
|
if((this instanceof PaletteOrHunk f && f.isPalette()))
|
||||||
{
|
{
|
||||||
PalettedContainer<T> c = new PalettedContainer<>();
|
PalettedContainer<T> c = new PalettedContainer<>();
|
||||||
List<T> palette = new ArrayList<>();
|
List<T> palette = new ArrayList<>();
|
||||||
|
@ -1,99 +0,0 @@
|
|||||||
/*
|
|
||||||
* Iris is a World Generator for Minecraft Bukkit Servers
|
|
||||||
* Copyright (c) 2021 Arcane Arts (Volmit Software)
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.volmit.iris.util.matter;
|
|
||||||
|
|
||||||
import com.volmit.iris.Iris;
|
|
||||||
import com.volmit.iris.core.IrisSettings;
|
|
||||||
import com.volmit.iris.util.collection.KList;
|
|
||||||
import com.volmit.iris.util.format.Form;
|
|
||||||
import com.volmit.iris.util.io.IO;
|
|
||||||
import com.volmit.iris.util.mantle.Mantle;
|
|
||||||
import com.volmit.iris.util.mantle.TectonicPlate;
|
|
||||||
import com.volmit.iris.util.math.RNG;
|
|
||||||
import com.volmit.iris.util.nbt.tag.ByteArrayTag;
|
|
||||||
import com.volmit.iris.util.scheduling.J;
|
|
||||||
import com.volmit.iris.util.scheduling.PrecisionStopwatch;
|
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.ByteArrayOutputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.ThreadLocalRandom;
|
|
||||||
|
|
||||||
public class MatterTest {
|
|
||||||
public static long memorySample()
|
|
||||||
{
|
|
||||||
Runtime rt = Runtime.getRuntime();
|
|
||||||
System.gc();
|
|
||||||
System.gc();
|
|
||||||
return rt.totalMemory() - rt.freeMemory();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void test()
|
|
||||||
{
|
|
||||||
for(Thread i : Thread.getAllStackTraces().keySet())
|
|
||||||
{
|
|
||||||
if(i.getId() != Thread.currentThread().getId())
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
i.wait(10000);
|
|
||||||
} catch (Throwable ignored) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
System.gc();
|
|
||||||
System.gc();
|
|
||||||
J.sleep(250);
|
|
||||||
|
|
||||||
try {
|
|
||||||
|
|
||||||
double ms = 0;
|
|
||||||
long a = memorySample();
|
|
||||||
PrecisionStopwatch p = PrecisionStopwatch.start();
|
|
||||||
IrisSettings.get().getPerformance().setUseExperimentalMantleMemoryCompression(true);
|
|
||||||
Mantle mantle = new Mantle(new File("mantle-test/legacy"), 256);
|
|
||||||
|
|
||||||
for(int i = 0; i < 512; i++)
|
|
||||||
{
|
|
||||||
for(int j = 0; j < 255; j++)
|
|
||||||
{
|
|
||||||
for(int k = 0; k < 512; k++)
|
|
||||||
{
|
|
||||||
mantle.set(i,j,k,RNG.r.chance(0.5));
|
|
||||||
mantle.set(i,j,k,RNG.r.chance(0.5)?"a" : "b");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ms += p.getMilliseconds();
|
|
||||||
long b = memorySample() - a;
|
|
||||||
Iris.info("Memory: " + Form.memSize(b, 0) + " (" + Form.f(b) + " bytes)");
|
|
||||||
p = PrecisionStopwatch.start();
|
|
||||||
mantle.saveAll();
|
|
||||||
mantle.close();
|
|
||||||
ms+=p.getMilliseconds();
|
|
||||||
Iris.info("Closed, done! took " + Form.duration(ms, 2));
|
|
||||||
} catch (Throwable e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -18,12 +18,15 @@
|
|||||||
|
|
||||||
package com.volmit.iris.util.nbt.mca;
|
package com.volmit.iris.util.nbt.mca;
|
||||||
|
|
||||||
|
import com.volmit.iris.core.pregenerator.syndicate.SyndicateServer;
|
||||||
import com.volmit.iris.util.collection.KList;
|
import com.volmit.iris.util.collection.KList;
|
||||||
import com.volmit.iris.util.math.Position2;
|
import com.volmit.iris.util.math.Position2;
|
||||||
import com.volmit.iris.util.nbt.tag.CompoundTag;
|
import com.volmit.iris.util.nbt.tag.CompoundTag;
|
||||||
|
import com.volmit.iris.util.scheduling.J;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.RandomAccessFile;
|
import java.io.RandomAccessFile;
|
||||||
|
import java.util.concurrent.ConcurrentLinkedQueue;
|
||||||
import java.util.concurrent.atomic.AtomicReferenceArray;
|
import java.util.concurrent.atomic.AtomicReferenceArray;
|
||||||
|
|
||||||
@SuppressWarnings("ALL")
|
@SuppressWarnings("ALL")
|
||||||
@ -37,6 +40,7 @@ public class MCAFile {
|
|||||||
private final int regionX;
|
private final int regionX;
|
||||||
private final int regionZ;
|
private final int regionZ;
|
||||||
private AtomicReferenceArray<Chunk> chunks;
|
private AtomicReferenceArray<Chunk> chunks;
|
||||||
|
private ConcurrentLinkedQueue<Runnable> afterSave;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* MCAFile represents a world save file used by Minecraft to store world
|
* MCAFile represents a world save file used by Minecraft to store world
|
||||||
@ -50,6 +54,7 @@ public class MCAFile {
|
|||||||
public MCAFile(int regionX, int regionZ) {
|
public MCAFile(int regionX, int regionZ) {
|
||||||
this.regionX = regionX;
|
this.regionX = regionX;
|
||||||
this.regionZ = regionZ;
|
this.regionZ = regionZ;
|
||||||
|
afterSave = new ConcurrentLinkedQueue<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -198,6 +203,11 @@ public class MCAFile {
|
|||||||
raf.seek(globalOffset * 4096L - 1);
|
raf.seek(globalOffset * 4096L - 1);
|
||||||
raf.write(0);
|
raf.write(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
J.a(() -> {
|
||||||
|
afterSave.forEach(i -> i.run());
|
||||||
|
}, 20);
|
||||||
|
|
||||||
return chunksWritten;
|
return chunksWritten;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -326,4 +336,8 @@ public class MCAFile {
|
|||||||
}
|
}
|
||||||
return chunk.getBlockStateAt(blockX, blockY, blockZ);
|
return chunk.getBlockStateAt(blockX, blockY, blockZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void afterSave(Runnable o) {
|
||||||
|
afterSave.add(o);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -329,4 +329,8 @@ public class NBTWorld {
|
|||||||
public int size() {
|
public int size() {
|
||||||
return loadedRegions.size();
|
return loadedRegions.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isLoaded(int x, int z) {
|
||||||
|
return loadedRegions.containsKey(Cache.key(x, z));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user