mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-07 12:56:31 +01:00
Feeling empty
- Log a warning and don't allocate any resources when an instancer is created with an empty model. - Log stacktrace starting from the call to InstancerProvider#instancer. - Revert switch to embeddium dep and comment why the rubidium dep is there.
This commit is contained in:
parent
de622ccc51
commit
ad27133253
4 changed files with 36 additions and 2 deletions
|
@ -5,6 +5,7 @@ import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.Flywheel;
|
||||||
import com.jozufozu.flywheel.api.event.RenderStage;
|
import com.jozufozu.flywheel.api.event.RenderStage;
|
||||||
import com.jozufozu.flywheel.api.instance.Instance;
|
import com.jozufozu.flywheel.api.instance.Instance;
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceType;
|
import com.jozufozu.flywheel.api.instance.InstanceType;
|
||||||
|
@ -51,6 +52,8 @@ public abstract class InstancerStorage<N extends AbstractInstancer<?>> {
|
||||||
return (Instancer<I>) instancer;
|
return (Instancer<I>) instancer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
maybeWarnEmptyModel(model);
|
||||||
|
|
||||||
// Create a new instancer and add it to the uninitialized list.
|
// Create a new instancer and add it to the uninitialized list.
|
||||||
instancer = create(type);
|
instancer = create(type);
|
||||||
instancers.put(key, instancer);
|
instancers.put(key, instancer);
|
||||||
|
@ -59,6 +62,23 @@ public abstract class InstancerStorage<N extends AbstractInstancer<?>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void maybeWarnEmptyModel(Model model) {
|
||||||
|
if (!model.meshes()
|
||||||
|
.isEmpty()) {
|
||||||
|
// All is good.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuilder builder = new StringBuilder();
|
||||||
|
builder.append("Creating an instancer for a model with no meshes! Stack trace:");
|
||||||
|
StackWalker.getInstance()
|
||||||
|
.walk(s -> s.skip(3)) // skip 3 to get back to the caller of InstancerProvider#instancer
|
||||||
|
.forEach(f -> builder.append("\n\t")
|
||||||
|
.append(f.toString()));
|
||||||
|
|
||||||
|
Flywheel.LOGGER.warn(builder.toString());
|
||||||
|
}
|
||||||
|
|
||||||
public void delete() {
|
public void delete() {
|
||||||
instancers.clear();
|
instancers.clear();
|
||||||
uninitializedInstancers.clear();
|
uninitializedInstancers.clear();
|
||||||
|
|
|
@ -46,6 +46,12 @@ public class IndirectDrawManager extends InstancerStorage<IndirectInstancer<?>>
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
protected <I extends Instance> void add(InstancerKey<I> key, IndirectInstancer<?> instancer, Model model, RenderStage stage) {
|
protected <I extends Instance> void add(InstancerKey<I> key, IndirectInstancer<?> instancer, Model model, RenderStage stage) {
|
||||||
|
if (model.meshes()
|
||||||
|
.isEmpty()) {
|
||||||
|
// Don't bother allocating resources for models with no meshes.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
var group = (IndirectCullingGroup<I>) cullingGroups.computeIfAbsent(key.type(), IndirectCullingGroup::new);
|
var group = (IndirectCullingGroup<I>) cullingGroups.computeIfAbsent(key.type(), IndirectCullingGroup::new);
|
||||||
group.add((IndirectInstancer<I>) instancer, model, stage);
|
group.add((IndirectInstancer<I>) instancer, model, stage);
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,6 +65,12 @@ public class InstancedDrawManager extends InstancerStorage<InstancedInstancer<?>
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected <I extends Instance> void add(InstancerKey<I> key, InstancedInstancer<?> instancer, Model model, RenderStage stage) {
|
protected <I extends Instance> void add(InstancerKey<I> key, InstancedInstancer<?> instancer, Model model, RenderStage stage) {
|
||||||
|
if (model.meshes()
|
||||||
|
.isEmpty()) {
|
||||||
|
// Don't bother allocating resources for models with no meshes.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
instancer.init();
|
instancer.init();
|
||||||
|
|
||||||
DrawSet drawSet = drawSets.computeIfAbsent(stage, DrawSet::new);
|
DrawSet drawSet = drawSets.computeIfAbsent(stage, DrawSet::new);
|
||||||
|
|
|
@ -30,8 +30,10 @@ ordering = "NONE"
|
||||||
side = "CLIENT"
|
side = "CLIENT"
|
||||||
|
|
||||||
[[dependencies.flywheel]]
|
[[dependencies.flywheel]]
|
||||||
modId = "embeddium"
|
modId = "rubidium"
|
||||||
mandatory = false
|
mandatory = false
|
||||||
versionRange = "${embeddium_version_range}"
|
# This should be a "breaks" dependency.
|
||||||
|
# There's a mixin crash with Rubidum < 0.7.0
|
||||||
|
versionRange = "[0.7.0,)"
|
||||||
ordering = "NONE"
|
ordering = "NONE"
|
||||||
side = "CLIENT"
|
side = "CLIENT"
|
||||||
|
|
Loading…
Reference in a new issue