Rename/refactor many interfaces

- Drop I prefix
 - Inline IMultiProgram
 - Remove unused method in InstanceRendered
This commit is contained in:
Jozufozu 2021-09-28 17:54:47 -07:00
parent 39ce96ec9c
commit 18ed201c93
53 changed files with 154 additions and 178 deletions

View file

@ -42,7 +42,7 @@ public class Backend {
private boolean enabled; private boolean enabled;
public boolean chunkCachingEnabled; public boolean chunkCachingEnabled;
private final List<IShaderContext<?>> contexts = new ArrayList<>(); private final List<ShaderContext<?>> contexts = new ArrayList<>();
private final Map<ResourceLocation, MaterialSpec<?>> materialRegistry = new HashMap<>(); private final Map<ResourceLocation, MaterialSpec<?>> materialRegistry = new HashMap<>();
private final Map<ResourceLocation, ProgramSpec> programSpecRegistry = new HashMap<>(); private final Map<ResourceLocation, ProgramSpec> programSpecRegistry = new HashMap<>();
@ -83,7 +83,7 @@ public class Backend {
/** /**
* Register a shader context. * Register a shader context.
*/ */
public <C extends IShaderContext<?>> C register(C spec) { public <C extends ShaderContext<?>> C register(C spec) {
contexts.add(spec); contexts.add(spec);
return spec; return spec;
} }
@ -154,7 +154,7 @@ public class Backend {
return programSpecRegistry.values(); return programSpecRegistry.values();
} }
public Collection<IShaderContext<?>> allContexts() { public Collection<ShaderContext<?>> allContexts() {
return contexts; return contexts;
} }
@ -164,7 +164,7 @@ public class Backend {
public static boolean isFlywheelWorld(@Nullable LevelAccessor world) { public static boolean isFlywheelWorld(@Nullable LevelAccessor world) {
if (world == null) return false; if (world == null) return false;
if (world instanceof IFlywheelWorld && ((IFlywheelWorld) world).supportsFlywheel()) return true; if (world instanceof FlywheelWorld && ((FlywheelWorld) world).supportsFlywheel()) return true;
return world == Minecraft.getInstance().level; return world == Minecraft.getInstance().level;
} }
@ -183,7 +183,7 @@ public class Backend {
public void _clearContexts() { public void _clearContexts() {
SpecMetaRegistry.clear(); SpecMetaRegistry.clear();
programSpecRegistry.clear(); programSpecRegistry.clear();
contexts.forEach(IShaderContext::delete); contexts.forEach(ShaderContext::delete);
contexts.clear(); contexts.clear();
materialRegistry.clear(); materialRegistry.clear();
} }

View file

@ -6,7 +6,7 @@ package com.jozufozu.flywheel.backend;
* *
* <code>Minecraft.getInstance().world</code> is special cased and will support Flywheel by default. * <code>Minecraft.getInstance().world</code> is special cased and will support Flywheel by default.
*/ */
public interface IFlywheelWorld { public interface FlywheelWorld {
default boolean supportsFlywheel() { default boolean supportsFlywheel() {
return true; return true;
} }

View file

@ -82,7 +82,7 @@ public class Loader implements ResourceManagerReloadListener {
Resolver.INSTANCE.resolve(sources); Resolver.INSTANCE.resolve(sources);
for (IShaderContext<?> context : backend.allContexts()) { for (ShaderContext<?> context : backend.allContexts()) {
context.load(); context.load();
} }

View file

@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.gl.shader.GlProgram;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
public interface IShaderContext<P extends GlProgram> { public interface ShaderContext<P extends GlProgram> {
default P getProgram(ResourceLocation loc) { default P getProgram(ResourceLocation loc) {
return this.getProgramSupplier(loc) return this.getProgramSupplier(loc)

View file

@ -1,6 +1,6 @@
package com.jozufozu.flywheel.backend.gl.attrib; package com.jozufozu.flywheel.backend.gl.attrib;
public interface IAttribSpec { public interface AttribSpec {
void vertexAttribPointer(int stride, int index, int offset); void vertexAttribPointer(int stride, int index, int offset);

View file

@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20;
import com.jozufozu.flywheel.backend.gl.GlNumericType; import com.jozufozu.flywheel.backend.gl.GlNumericType;
public enum MatrixAttributes implements IAttribSpec { public enum MatrixAttributes implements AttribSpec {
MAT3(3, 3), MAT3(3, 3),
MAT4(4, 4), MAT4(4, 4),
; ;

View file

@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20;
import com.jozufozu.flywheel.backend.gl.GlNumericType; import com.jozufozu.flywheel.backend.gl.GlNumericType;
public class VertexAttribSpec implements IAttribSpec { public class VertexAttribSpec implements AttribSpec {
private final GlNumericType type; private final GlNumericType type;
private final int count; private final int count;

View file

@ -5,16 +5,16 @@ import java.util.Collections;
public class VertexFormat { public class VertexFormat {
private final ArrayList<IAttribSpec> allAttributes; private final ArrayList<AttribSpec> allAttributes;
private final int numAttributes; private final int numAttributes;
private final int stride; private final int stride;
public VertexFormat(ArrayList<IAttribSpec> allAttributes) { public VertexFormat(ArrayList<AttribSpec> allAttributes) {
this.allAttributes = allAttributes; this.allAttributes = allAttributes;
int numAttributes = 0, stride = 0; int numAttributes = 0, stride = 0;
for (IAttribSpec spec : allAttributes) { for (AttribSpec spec : allAttributes) {
numAttributes += spec.getAttributeCount(); numAttributes += spec.getAttributeCount();
stride += spec.getSize(); stride += spec.getSize();
} }
@ -32,7 +32,7 @@ public class VertexFormat {
public void vertexAttribPointers(int index) { public void vertexAttribPointers(int index) {
int offset = 0; int offset = 0;
for (IAttribSpec spec : this.allAttributes) { for (AttribSpec spec : this.allAttributes) {
spec.vertexAttribPointer(stride, index, offset); spec.vertexAttribPointer(stride, index, offset);
index += spec.getAttributeCount(); index += spec.getAttributeCount();
offset += spec.getSize(); offset += spec.getSize();
@ -44,12 +44,12 @@ public class VertexFormat {
} }
public static class Builder { public static class Builder {
private final ArrayList<IAttribSpec> allAttributes = new ArrayList<>(); private final ArrayList<AttribSpec> allAttributes = new ArrayList<>();
public Builder() { public Builder() {
} }
public Builder addAttributes(IAttribSpec... attributes) { public Builder addAttributes(AttribSpec... attributes) {
Collections.addAll(allAttributes, attributes); Collections.addAll(allAttributes, attributes);
return this; return this;
} }

View file

@ -5,7 +5,7 @@ import java.util.stream.Stream;
import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager; import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.core.materials.IFlatLight; import com.jozufozu.flywheel.core.materials.FlatLight;
import com.jozufozu.flywheel.light.ILightUpdateListener; import com.jozufozu.flywheel.light.ILightUpdateListener;
import com.jozufozu.flywheel.light.ImmutableBox; import com.jozufozu.flywheel.light.ImmutableBox;
import com.jozufozu.flywheel.light.LightProvider; import com.jozufozu.flywheel.light.LightProvider;
@ -19,7 +19,7 @@ import net.minecraft.world.level.Level;
* A general interface providing information about any type of thing that could use Flywheel's instanced rendering. * A general interface providing information about any type of thing that could use Flywheel's instanced rendering.
* Right now, that's only {@link TileInstanceManager}, but there could be an entity equivalent in the future. * Right now, that's only {@link TileInstanceManager}, but there could be an entity equivalent in the future.
*/ */
public abstract class AbstractInstance implements IInstance, ILightUpdateListener { public abstract class AbstractInstance implements Instance, ILightUpdateListener {
protected final MaterialManager materialManager; protected final MaterialManager materialManager;
public final Level world; public final Level world;
@ -38,7 +38,7 @@ public abstract class AbstractInstance implements IInstance, ILightUpdateListene
* Update instance data here. Good for when data doesn't change very often and when animations are GPU based. * Update instance data here. Good for when data doesn't change very often and when animations are GPU based.
* Don't query lighting data here, that's handled separately in {@link #updateLight()}. * Don't query lighting data here, that's handled separately in {@link #updateLight()}.
* *
* <br><br> If your animations are complex or more CPU driven, see {@link IDynamicInstance} or {@link ITickableInstance}. * <br><br> If your animations are complex or more CPU driven, see {@link DynamicInstance} or {@link TickableInstance}.
*/ */
public void update() { public void update() {
} }
@ -77,19 +77,19 @@ public abstract class AbstractInstance implements IInstance, ILightUpdateListene
updateLight(); updateLight();
} }
protected void relight(BlockPos pos, IFlatLight<?>... models) { protected void relight(BlockPos pos, FlatLight... models) {
relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models); relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models);
} }
protected <L extends IFlatLight<?>> void relight(BlockPos pos, Stream<L> models) { protected <L extends FlatLight> void relight(BlockPos pos, Stream<L> models) {
relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models); relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models);
} }
protected void relight(int block, int sky, IFlatLight<?>... models) { protected void relight(int block, int sky, FlatLight... models) {
relight(block, sky, Arrays.stream(models)); relight(block, sky, Arrays.stream(models));
} }
protected <L extends IFlatLight<?>> void relight(int block, int sky, Stream<L> models) { protected <L extends FlatLight> void relight(int block, int sky, Stream<L> models) {
models.forEach(model -> model.setBlockLight(block) models.forEach(model -> model.setBlockLight(block)
.setSkyLight(sky)); .setSkyLight(sky));
} }

View file

@ -4,14 +4,14 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
/** /**
* An interface giving {@link TileEntityInstance}s a hook to have a function called at * An interface giving {@link TileEntityInstance}s a hook to have a function called at
* the start of a frame. By implementing {@link IDynamicInstance}, a {@link TileEntityInstance} * the start of a frame. By implementing {@link DynamicInstance}, a {@link TileEntityInstance}
* can animate its models in ways that could not be easily achieved by shader attribute * can animate its models in ways that could not be easily achieved by shader attribute
* parameterization. * parameterization.
* *
* <br><br> If your goal is offloading work to shaders, but you're unsure exactly how you need * <br><br> If your goal is offloading work to shaders, but you're unsure exactly how you need
* to parameterize the instances, you're encouraged to implement this for prototyping. * to parameterize the instances, you're encouraged to implement this for prototyping.
*/ */
public interface IDynamicInstance extends IInstance { public interface DynamicInstance extends Instance {
/** /**
* Called every frame. * Called every frame.
* <br> * <br>

View file

@ -13,13 +13,13 @@ import com.jozufozu.flywheel.backend.model.IBufferedModel;
import com.jozufozu.flywheel.backend.model.ModelAllocator; import com.jozufozu.flywheel.backend.model.ModelAllocator;
import com.jozufozu.flywheel.backend.struct.StructType; import com.jozufozu.flywheel.backend.struct.StructType;
import com.jozufozu.flywheel.backend.struct.StructWriter; import com.jozufozu.flywheel.backend.struct.StructWriter;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.util.AttribUtil; import com.jozufozu.flywheel.util.AttribUtil;
public class GPUInstancer<D extends InstanceData> implements Instancer<D> { public class GPUInstancer<D extends InstanceData> implements Instancer<D> {
private final ModelAllocator modelAllocator; private final ModelAllocator modelAllocator;
private final IModel modelData; private final Model modelData;
private final VertexFormat instanceFormat; private final VertexFormat instanceFormat;
private final StructType<D> type; private final StructType<D> type;
@ -36,7 +36,7 @@ public class GPUInstancer<D extends InstanceData> implements Instancer<D> {
boolean anyToRemove; boolean anyToRemove;
boolean anyToUpdate; boolean anyToUpdate;
public GPUInstancer(ModelAllocator modelAllocator, IModel model, StructType<D> type) { public GPUInstancer(ModelAllocator modelAllocator, Model model, StructType<D> type) {
this.modelAllocator = modelAllocator; this.modelAllocator = modelAllocator;
this.modelData = model; this.modelData = model;
this.type = type; this.type = type;

View file

@ -2,6 +2,6 @@ package com.jozufozu.flywheel.backend.instancing;
import net.minecraft.core.BlockPos; import net.minecraft.core.BlockPos;
public interface IInstance { public interface Instance {
BlockPos getWorldPosition(); BlockPos getWorldPosition();
} }

View file

@ -27,8 +27,8 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
private final Set<T> queuedUpdates; private final Set<T> queuedUpdates;
protected final Map<T, AbstractInstance> instances; protected final Map<T, AbstractInstance> instances;
protected final Object2ObjectOpenHashMap<T, ITickableInstance> tickableInstances; protected final Object2ObjectOpenHashMap<T, TickableInstance> tickableInstances;
protected final Object2ObjectOpenHashMap<T, IDynamicInstance> dynamicInstances; protected final Object2ObjectOpenHashMap<T, DynamicInstance> dynamicInstances;
protected int frame; protected int frame;
protected int tick; protected int tick;
@ -70,7 +70,7 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
* Ticks the InstanceManager. * Ticks the InstanceManager.
* *
* <p> * <p>
* {@link ITickableInstance}s get ticked. * {@link TickableInstance}s get ticked.
* <br> * <br>
* Queued updates are processed. * Queued updates are processed.
* </p> * </p>
@ -86,7 +86,7 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
if (tickableInstances.size() > 0) { if (tickableInstances.size() > 0) {
tickableInstances.object2ObjectEntrySet().parallelStream().forEach(e -> { tickableInstances.object2ObjectEntrySet().parallelStream().forEach(e -> {
ITickableInstance instance = e.getValue(); TickableInstance instance = e.getValue();
if (!instance.decreaseTickRateWithDistance()) { if (!instance.decreaseTickRateWithDistance()) {
instance.tick(); instance.tick();
return; return;
@ -121,7 +121,7 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
dynamicInstances.object2ObjectEntrySet() dynamicInstances.object2ObjectEntrySet()
.parallelStream() .parallelStream()
.forEach(e -> { .forEach(e -> {
IDynamicInstance dyn = e.getValue(); DynamicInstance dyn = e.getValue();
if (!dyn.decreaseFramerateWithDistance() || shouldFrameUpdate(dyn.getWorldPosition(), lookX, lookY, lookZ, cX, cY, cZ)) if (!dyn.decreaseFramerateWithDistance() || shouldFrameUpdate(dyn.getWorldPosition(), lookX, lookY, lookZ, cX, cY, cZ))
dyn.beginFrame(); dyn.beginFrame();
}); });
@ -159,8 +159,8 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
* *
* <p> * <p>
* By default this is the only hook an IInstance has to change its internal state. This is the lowest frequency * By default this is the only hook an IInstance has to change its internal state. This is the lowest frequency
* update hook IInstance gets. For more frequent updates, see {@link ITickableInstance} and * update hook IInstance gets. For more frequent updates, see {@link TickableInstance} and
* {@link IDynamicInstance}. * {@link DynamicInstance}.
* </p> * </p>
* *
* @param obj the object to update. * @param obj the object to update.
@ -291,9 +291,9 @@ public abstract class InstanceManager<T> implements MaterialManagerImpl.OriginSh
.addListener(renderer); .addListener(renderer);
instances.put(obj, renderer); instances.put(obj, renderer);
if (renderer instanceof IDynamicInstance) dynamicInstances.put(obj, (IDynamicInstance) renderer); if (renderer instanceof DynamicInstance) dynamicInstances.put(obj, (DynamicInstance) renderer);
if (renderer instanceof ITickableInstance) tickableInstances.put(obj, ((ITickableInstance) renderer)); if (renderer instanceof TickableInstance) tickableInstances.put(obj, ((TickableInstance) renderer));
} }
return renderer; return renderer;

View file

@ -1,11 +1,9 @@
package com.jozufozu.flywheel.backend.instancing; package com.jozufozu.flywheel.backend.instancing;
import net.minecraft.world.level.Level;
/** /**
* Something (a BlockEntity or Entity) that can be rendered using the instancing API. * Something (a BlockEntity or Entity) that can be rendered using the instancing API.
*/ */
public interface IInstanceRendered { public interface InstanceRendered {
/** /**
* @return true if there are parts of the renderer that cannot be implemented with Flywheel. * @return true if there are parts of the renderer that cannot be implemented with Flywheel.
@ -13,6 +11,4 @@ public interface IInstanceRendered {
default boolean shouldRenderNormally() { default boolean shouldRenderNormally() {
return false; return false;
} }
Level getWorld();
} }

View file

@ -71,7 +71,7 @@ public class InstanceWorld {
* <p> * <p>
* Check and shift the origin coordinate. * Check and shift the origin coordinate.
* <br> * <br>
* Call {@link IDynamicInstance#beginFrame()} on all instances in this world. * Call {@link DynamicInstance#beginFrame()} on all instances in this world.
* </p> * </p>
*/ */
public void beginFrame(BeginFrameEvent event) { public void beginFrame(BeginFrameEvent event) {
@ -84,7 +84,7 @@ public class InstanceWorld {
/** /**
* Tick the renderers after the game has ticked: * Tick the renderers after the game has ticked:
* <p> * <p>
* Call {@link ITickableInstance#tick()} on all instances in this world. * Call {@link TickableInstance#tick()} on all instances in this world.
* </p> * </p>
*/ */
public void tick() { public void tick() {

View file

@ -6,8 +6,8 @@ import javax.annotation.Nullable;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance; import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance;
import com.jozufozu.flywheel.backend.instancing.entity.IEntityInstanceFactory; import com.jozufozu.flywheel.backend.instancing.entity.EntityInstanceFactory;
import com.jozufozu.flywheel.backend.instancing.tile.ITileInstanceFactory; import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceFactory;
import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
@ -26,19 +26,21 @@ public class InstancedRenderRegistry {
} }
private final Object2BooleanMap<Object> skipRender = new Object2BooleanLinkedOpenHashMap<>(); private final Object2BooleanMap<Object> skipRender = new Object2BooleanLinkedOpenHashMap<>();
private final Map<BlockEntityType<?>, ITileInstanceFactory<?>> tiles = Maps.newHashMap(); private final Map<BlockEntityType<?>, TileInstanceFactory<?>> tiles = Maps.newHashMap();
private final Map<EntityType<?>, IEntityInstanceFactory<?>> entities = Maps.newHashMap(); private final Map<EntityType<?>, EntityInstanceFactory<?>> entities = Maps.newHashMap();
protected InstancedRenderRegistry() { protected InstancedRenderRegistry() {
skipRender.defaultReturnValue(false); skipRender.defaultReturnValue(false);
} }
public <T extends BlockEntity> boolean shouldSkipRender(T type) { public <T extends BlockEntity> boolean shouldSkipRender(T type) {
return _skipRender(type.getType()) || ((type instanceof IInstanceRendered) && !((IInstanceRendered) type).shouldRenderNormally()); // _skipRender is faster than instanceof and cast, take advantage of short-circuiting
return _skipRender(type.getType()) || ((type instanceof InstanceRendered) && !((InstanceRendered) type).shouldRenderNormally());
} }
public <T extends Entity> boolean shouldSkipRender(T type) { public <T extends Entity> boolean shouldSkipRender(T type) {
return _skipRender(type.getType()) || ((type instanceof IInstanceRendered) && !((IInstanceRendered) type).shouldRenderNormally()); // _skipRender is faster than instanceof and cast, take advantage of short-circuiting
return _skipRender(type.getType()) || ((type instanceof InstanceRendered) && !((InstanceRendered) type).shouldRenderNormally());
} }
public <T extends BlockEntity> boolean canInstance(BlockEntityType<? extends T> type) { public <T extends BlockEntity> boolean canInstance(BlockEntityType<? extends T> type) {
@ -61,7 +63,7 @@ public class InstancedRenderRegistry {
* @deprecated will be removed in 0.3.0, use {@link #tile} * @deprecated will be removed in 0.3.0, use {@link #tile}
*/ */
@Deprecated @Deprecated
public <T extends BlockEntity> void register(BlockEntityType<? extends T> type, ITileInstanceFactory<? super T> rendererFactory) { public <T extends BlockEntity> void register(BlockEntityType<? extends T> type, TileInstanceFactory<? super T> rendererFactory) {
this.tile(type) this.tile(type)
.factory(rendererFactory); .factory(rendererFactory);
} }
@ -70,7 +72,7 @@ public class InstancedRenderRegistry {
* @deprecated will be removed in 0.3.0, use {@link #entity} * @deprecated will be removed in 0.3.0, use {@link #entity}
*/ */
@Deprecated @Deprecated
public <T extends Entity> void register(EntityType<? extends T> type, IEntityInstanceFactory<? super T> rendererFactory) { public <T extends Entity> void register(EntityType<? extends T> type, EntityInstanceFactory<? super T> rendererFactory) {
this.entity(type) this.entity(type)
.factory(rendererFactory); .factory(rendererFactory);
} }
@ -79,7 +81,7 @@ public class InstancedRenderRegistry {
@Nullable @Nullable
public <T extends BlockEntity> TileEntityInstance<? super T> create(MaterialManager manager, T tile) { public <T extends BlockEntity> TileEntityInstance<? super T> create(MaterialManager manager, T tile) {
BlockEntityType<?> type = tile.getType(); BlockEntityType<?> type = tile.getType();
ITileInstanceFactory<? super T> factory = (ITileInstanceFactory<? super T>) this.tiles.get(type); TileInstanceFactory<? super T> factory = (TileInstanceFactory<? super T>) this.tiles.get(type);
if (factory == null) return null; if (factory == null) return null;
else return factory.create(manager, tile); else return factory.create(manager, tile);
@ -90,7 +92,7 @@ public class InstancedRenderRegistry {
@Nullable @Nullable
public <T extends Entity> EntityInstance<? super T> create(MaterialManager manager, T tile) { public <T extends Entity> EntityInstance<? super T> create(MaterialManager manager, T tile) {
EntityType<?> type = tile.getType(); EntityType<?> type = tile.getType();
IEntityInstanceFactory<? super T> factory = (IEntityInstanceFactory<? super T>) this.entities.get(type); EntityInstanceFactory<? super T> factory = (EntityInstanceFactory<? super T>) this.entities.get(type);
if (factory == null) return null; if (factory == null) return null;
else return factory.create(manager, tile); else return factory.create(manager, tile);
@ -107,7 +109,7 @@ public class InstancedRenderRegistry {
CONFIG setSkipRender(boolean skipRender); CONFIG setSkipRender(boolean skipRender);
} }
public class TileConfig<T extends BlockEntity> implements Config<TileConfig<T>, ITileInstanceFactory<? super T>> { public class TileConfig<T extends BlockEntity> implements Config<TileConfig<T>, TileInstanceFactory<? super T>> {
private final BlockEntityType<T> type; private final BlockEntityType<T> type;
@ -116,7 +118,7 @@ public class InstancedRenderRegistry {
this.type = type; this.type = type;
} }
public TileConfig<T> factory(ITileInstanceFactory<? super T> rendererFactory) { public TileConfig<T> factory(TileInstanceFactory<? super T> rendererFactory) {
tiles.put(type, rendererFactory); tiles.put(type, rendererFactory);
return this; return this;
} }
@ -126,7 +128,7 @@ public class InstancedRenderRegistry {
} }
} }
public class EntityConfig<T extends Entity> implements Config<EntityConfig<T>, IEntityInstanceFactory<? super T>> { public class EntityConfig<T extends Entity> implements Config<EntityConfig<T>, EntityInstanceFactory<? super T>> {
private final EntityType<T> type; private final EntityType<T> type;
@ -135,7 +137,7 @@ public class InstancedRenderRegistry {
this.type = type; this.type = type;
} }
public EntityConfig<T> factory(IEntityInstanceFactory<? super T> rendererFactory) { public EntityConfig<T> factory(EntityInstanceFactory<? super T> rendererFactory) {
entities.put(type, rendererFactory); entities.put(type, rendererFactory);
return this; return this;
} }

View file

@ -4,9 +4,9 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
/** /**
* An interface giving {@link TileEntityInstance}s a hook to have a function called at * An interface giving {@link TileEntityInstance}s a hook to have a function called at
* the end of every tick. By implementing {@link ITickableInstance}, a {@link TileEntityInstance} * the end of every tick. By implementing {@link TickableInstance}, a {@link TileEntityInstance}
* can update frequently, but not every frame. * can update frequently, but not every frame.
* <br> There are a few cases in which this should be considered over {@link IDynamicInstance}: * <br> There are a few cases in which this should be considered over {@link DynamicInstance}:
* <ul> * <ul>
* <li> * <li>
* You'd like to change something about the instance every now and then. * You'd like to change something about the instance every now and then.
@ -18,7 +18,7 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
* </li> * </li>
* </ul> * </ul>
*/ */
public interface ITickableInstance extends IInstance { public interface TickableInstance extends Instance {
/** /**
* Called every tick. * Called every tick.

View file

@ -1,8 +1,8 @@
package com.jozufozu.flywheel.backend.instancing.entity; package com.jozufozu.flywheel.backend.instancing.entity;
import com.jozufozu.flywheel.backend.instancing.AbstractInstance; import com.jozufozu.flywheel.backend.instancing.AbstractInstance;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.ITickableInstance; import com.jozufozu.flywheel.backend.instancing.TickableInstance;
import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager; import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.light.GridAlignedBB; import com.jozufozu.flywheel.light.GridAlignedBB;
@ -24,8 +24,8 @@ import net.minecraft.core.Vec3i;
* * * *
* <br><br> There are a few additional features that overriding classes can opt in to: * <br><br> There are a few additional features that overriding classes can opt in to:
* <ul> * <ul>
* <li>{@link IDynamicInstance}</li> * <li>{@link DynamicInstance}</li>
* <li>{@link ITickableInstance}</li> * <li>{@link TickableInstance}</li>
* </ul> * </ul>
* See the interfaces' documentation for more information about each one. * See the interfaces' documentation for more information about each one.
* *

View file

@ -5,6 +5,6 @@ import com.jozufozu.flywheel.backend.material.MaterialManager;
import net.minecraft.world.entity.Entity; import net.minecraft.world.entity.Entity;
@FunctionalInterface @FunctionalInterface
public interface IEntityInstanceFactory<E extends Entity> { public interface EntityInstanceFactory<E extends Entity> {
EntityInstance<? super E> create(MaterialManager manager, E te); EntityInstance<? super E> create(MaterialManager manager, E te);
} }

View file

@ -1,8 +1,8 @@
package com.jozufozu.flywheel.backend.instancing.tile; package com.jozufozu.flywheel.backend.instancing.tile;
import com.jozufozu.flywheel.backend.instancing.AbstractInstance; import com.jozufozu.flywheel.backend.instancing.AbstractInstance;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.ITickableInstance; import com.jozufozu.flywheel.backend.instancing.TickableInstance;
import com.jozufozu.flywheel.backend.material.Material; import com.jozufozu.flywheel.backend.material.Material;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.Materials;
@ -22,8 +22,8 @@ import net.minecraft.core.BlockPos;
* *
* <br><br> There are a few additional features that overriding classes can opt in to: * <br><br> There are a few additional features that overriding classes can opt in to:
* <ul> * <ul>
* <li>{@link IDynamicInstance}</li> * <li>{@link DynamicInstance}</li>
* <li>{@link ITickableInstance}</li> * <li>{@link TickableInstance}</li>
* </ul> * </ul>
* See the interfaces' documentation for more information about each one. * See the interfaces' documentation for more information about each one.
* *

View file

@ -5,6 +5,6 @@ import com.jozufozu.flywheel.backend.material.MaterialManager;
import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntity;
@FunctionalInterface @FunctionalInterface
public interface ITileInstanceFactory<T extends BlockEntity> { public interface TileInstanceFactory<T extends BlockEntity> {
TileEntityInstance<? super T> create(MaterialManager manager, T te); TileEntityInstance<? super T> create(MaterialManager manager, T te);
} }

View file

@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.instancing.InstanceData;
import com.jozufozu.flywheel.backend.instancing.Instancer; import com.jozufozu.flywheel.backend.instancing.Instancer;
import com.jozufozu.flywheel.core.PartialModel; import com.jozufozu.flywheel.core.PartialModel;
import com.jozufozu.flywheel.core.model.BlockModel; import com.jozufozu.flywheel.core.model.BlockModel;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.util.Pair; import com.jozufozu.flywheel.util.Pair;
import com.jozufozu.flywheel.util.RenderUtil; import com.jozufozu.flywheel.util.RenderUtil;
import com.mojang.blaze3d.vertex.PoseStack; import com.mojang.blaze3d.vertex.PoseStack;
@ -22,7 +22,7 @@ public interface Material<D extends InstanceData> {
* @param modelSupplier A factory that creates the IModel that you want to render. * @param modelSupplier A factory that creates the IModel that you want to render.
* @return An instancer for the given model, capable of rendering many copies for little cost. * @return An instancer for the given model, capable of rendering many copies for little cost.
*/ */
Instancer<D> model(Object key, Supplier<IModel> modelSupplier); Instancer<D> model(Object key, Supplier<Model> modelSupplier);
default Instancer<D> getModel(PartialModel partial, BlockState referenceState) { default Instancer<D> getModel(PartialModel partial, BlockState referenceState) {
return model(partial, () -> new BlockModel(partial.get(), referenceState)); return model(partial, () -> new BlockModel(partial.get(), referenceState));

View file

@ -10,7 +10,7 @@ import com.jozufozu.flywheel.backend.instancing.GPUInstancer;
import com.jozufozu.flywheel.backend.instancing.InstanceData; import com.jozufozu.flywheel.backend.instancing.InstanceData;
import com.jozufozu.flywheel.backend.instancing.Instancer; import com.jozufozu.flywheel.backend.instancing.Instancer;
import com.jozufozu.flywheel.backend.model.ModelPool; import com.jozufozu.flywheel.backend.model.ModelPool;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
/** /**
* A collection of Instancers that all have the same format. * A collection of Instancers that all have the same format.
@ -42,7 +42,7 @@ public class MaterialImpl<D extends InstanceData> implements Material<D> {
* @return An instancer for the given model, capable of rendering many copies for little cost. * @return An instancer for the given model, capable of rendering many copies for little cost.
*/ */
@Override @Override
public Instancer<D> model(Object key, Supplier<IModel> modelSupplier) { public Instancer<D> model(Object key, Supplier<Model> modelSupplier) {
try { try {
return models.get(key, () -> new GPUInstancer<>(modelPool, modelSupplier.get(), spec.getInstanceType())); return models.get(key, () -> new GPUInstancer<>(modelPool, modelSupplier.get(), spec.getInstanceType()));
} catch (ExecutionException e) { } catch (ExecutionException e) {

View file

@ -4,6 +4,7 @@ import com.jozufozu.flywheel.backend.state.IRenderState;
import com.jozufozu.flywheel.backend.state.RenderLayer; import com.jozufozu.flywheel.backend.state.RenderLayer;
import com.jozufozu.flywheel.backend.state.TextureRenderState; import com.jozufozu.flywheel.backend.state.TextureRenderState;
import net.minecraft.client.renderer.RenderStateShard;
import net.minecraft.world.inventory.InventoryMenu; import net.minecraft.world.inventory.InventoryMenu;
import net.minecraft.core.Vec3i; import net.minecraft.core.Vec3i;

View file

@ -3,14 +3,14 @@ package com.jozufozu.flywheel.backend.model;
import java.util.function.Supplier; import java.util.function.Supplier;
import com.jozufozu.flywheel.backend.gl.GlVertexArray; import com.jozufozu.flywheel.backend.gl.GlVertexArray;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.util.AttribUtil; import com.jozufozu.flywheel.util.AttribUtil;
public class ArrayModelRenderer extends ModelRenderer { public class ArrayModelRenderer extends ModelRenderer {
protected GlVertexArray vao; protected GlVertexArray vao;
public ArrayModelRenderer(Supplier<IModel> model) { public ArrayModelRenderer(Supplier<Model> model) {
super(model); super(model);
} }
@ -29,7 +29,7 @@ public class ArrayModelRenderer extends ModelRenderer {
@Override @Override
protected void init() { protected void init() {
initialized = true; initialized = true;
IModel model = modelSupplier.get(); Model model = modelSupplier.get();
if (model.empty()) return; if (model.empty()) return;

View file

@ -9,17 +9,17 @@ import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType; import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.util.AttribUtil; import com.jozufozu.flywheel.util.AttribUtil;
public class BufferedModel implements IBufferedModel { public class BufferedModel implements IBufferedModel {
protected final IModel model; protected final Model model;
protected final GlPrimitive primitiveMode; protected final GlPrimitive primitiveMode;
protected GlBuffer vbo; protected GlBuffer vbo;
protected boolean deleted; protected boolean deleted;
public BufferedModel(GlPrimitive primitiveMode, IModel model) { public BufferedModel(GlPrimitive primitiveMode, Model model) {
this.model = model; this.model = model;
this.primitiveMode = primitiveMode; this.primitiveMode = primitiveMode;

View file

@ -1,13 +1,13 @@
package com.jozufozu.flywheel.backend.model; package com.jozufozu.flywheel.backend.model;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
public class ImmediateAllocator implements ModelAllocator { public class ImmediateAllocator implements ModelAllocator {
public static final ImmediateAllocator INSTANCE = new ImmediateAllocator(); public static final ImmediateAllocator INSTANCE = new ImmediateAllocator();
@Override @Override
public IBufferedModel alloc(IModel model, Callback allocationCallback) { public IBufferedModel alloc(Model model, Callback allocationCallback) {
IndexedModel out = new IndexedModel(model); IndexedModel out = new IndexedModel(model);
allocationCallback.onAlloc(out); allocationCallback.onAlloc(out);
return out; return out;

View file

@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20;
import com.jozufozu.flywheel.backend.Backend; import com.jozufozu.flywheel.backend.Backend;
import com.jozufozu.flywheel.backend.gl.GlPrimitive; import com.jozufozu.flywheel.backend.gl.GlPrimitive;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
/** /**
* An indexed triangle model. Just what the driver ordered. * An indexed triangle model. Just what the driver ordered.
@ -15,7 +15,7 @@ public class IndexedModel extends BufferedModel {
protected ElementBuffer ebo; protected ElementBuffer ebo;
public IndexedModel(IModel model) { public IndexedModel(Model model) {
super(GlPrimitive.TRIANGLES, model); super(GlPrimitive.TRIANGLES, model);
this.ebo = model.createEBO(); this.ebo = model.createEBO();

View file

@ -1,6 +1,6 @@
package com.jozufozu.flywheel.backend.model; package com.jozufozu.flywheel.backend.model;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
public interface ModelAllocator { public interface ModelAllocator {
/** /**
@ -9,7 +9,7 @@ public interface ModelAllocator {
* @param model The model to allocate. * @param model The model to allocate.
* @return A handle to the allocated model. * @return A handle to the allocated model.
*/ */
IBufferedModel alloc(IModel model, Callback allocationCallback); IBufferedModel alloc(Model model, Callback allocationCallback);
@FunctionalInterface @FunctionalInterface
interface Callback { interface Callback {

View file

@ -10,7 +10,7 @@ import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType; import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.util.AttribUtil; import com.jozufozu.flywheel.util.AttribUtil;
public class ModelPool implements ModelAllocator { public class ModelPool implements ModelAllocator {
@ -47,7 +47,7 @@ public class ModelPool implements ModelAllocator {
* @return A handle to the allocated model. * @return A handle to the allocated model.
*/ */
@Override @Override
public PooledModel alloc(IModel model, Callback callback) { public PooledModel alloc(Model model, Callback callback) {
PooledModel bufferedModel = new PooledModel(model, vertices); PooledModel bufferedModel = new PooledModel(model, vertices);
bufferedModel.callback = callback; bufferedModel.callback = callback;
vertices += model.vertexCount(); vertices += model.vertexCount();
@ -153,12 +153,12 @@ public class ModelPool implements ModelAllocator {
private final ElementBuffer ebo; private final ElementBuffer ebo;
private Callback callback; private Callback callback;
private final IModel model; private final Model model;
private int first; private int first;
private boolean remove; private boolean remove;
public PooledModel(IModel model, int first) { public PooledModel(Model model, int first) {
this.model = model; this.model = model;
this.first = first; this.first = first;
ebo = model.createEBO(); ebo = model.createEBO();

View file

@ -2,16 +2,16 @@ package com.jozufozu.flywheel.backend.model;
import java.util.function.Supplier; import java.util.function.Supplier;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
public class ModelRenderer { public class ModelRenderer {
protected Supplier<IModel> modelSupplier; protected Supplier<Model> modelSupplier;
protected IBufferedModel model; protected IBufferedModel model;
protected boolean initialized; protected boolean initialized;
public ModelRenderer(Supplier<IModel> modelSupplier) { public ModelRenderer(Supplier<Model> modelSupplier) {
this.modelSupplier = modelSupplier; this.modelSupplier = modelSupplier;
} }
@ -34,7 +34,7 @@ public class ModelRenderer {
protected void init() { protected void init() {
initialized = true; initialized = true;
IModel model = modelSupplier.get(); Model model = modelSupplier.get();
if (model.empty()) return; if (model.empty()) return;

View file

@ -1,15 +1,15 @@
package com.jozufozu.flywheel.backend.pipeline; package com.jozufozu.flywheel.backend.pipeline;
import com.jozufozu.flywheel.core.shader.IMultiProgram; import com.jozufozu.flywheel.backend.gl.shader.GlProgram;
import com.jozufozu.flywheel.core.shader.WorldProgram; import com.jozufozu.flywheel.core.shader.GameStateProgram;
import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec;
/** /**
* The main interface for compiling usable shaders from program specs. * The main interface for compiling usable shaders from program specs.
* @param <P> the type of the program that this pipeline compiles. * @param <P> the type of the program that this pipeline compiles.
*/ */
public interface IShaderPipeline<P extends WorldProgram> { public interface ShaderCompiler<P extends GlProgram> {
IMultiProgram<P> compile(ProgramSpec spec); GameStateProgram<P> compile(ProgramSpec spec);
} }

View file

@ -9,34 +9,33 @@ import com.jozufozu.flywheel.backend.source.FileResolution;
import com.jozufozu.flywheel.backend.source.SourceFile; import com.jozufozu.flywheel.backend.source.SourceFile;
import com.jozufozu.flywheel.core.shader.ExtensibleGlProgram; import com.jozufozu.flywheel.core.shader.ExtensibleGlProgram;
import com.jozufozu.flywheel.core.shader.GameStateProgram; import com.jozufozu.flywheel.core.shader.GameStateProgram;
import com.jozufozu.flywheel.core.shader.IMultiProgram;
import com.jozufozu.flywheel.core.shader.WorldProgram; import com.jozufozu.flywheel.core.shader.WorldProgram;
import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec;
import com.jozufozu.flywheel.core.shader.spec.ProgramState; import com.jozufozu.flywheel.core.shader.spec.ProgramState;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
public class WorldShaderPipeline<P extends WorldProgram> implements IShaderPipeline<P> { public class WorldShaderCompiler<P extends WorldProgram> implements ShaderCompiler<P> {
private final ExtensibleGlProgram.Factory<P> factory; private final ExtensibleGlProgram.Factory<P> factory;
private final Template<?> template; private final Template<?> template;
private final FileResolution header; private final FileResolution header;
public WorldShaderPipeline(ExtensibleGlProgram.Factory<P> factory, Template<?> template, FileResolution header) { public WorldShaderCompiler(ExtensibleGlProgram.Factory<P> factory, Template<?> template, FileResolution header) {
this.factory = factory; this.factory = factory;
this.template = template; this.template = template;
this.header = header; this.header = header;
} }
public IMultiProgram<P> compile(ProgramSpec spec) { public GameStateProgram<P> compile(ProgramSpec spec) {
SourceFile file = spec.getSource().getFile(); SourceFile file = spec.getSource().getFile();
return compile(spec.name, file, spec.getStates()); return compile(spec.name, file, spec.getStates());
} }
public IMultiProgram<P> compile(ResourceLocation name, SourceFile file, List<ProgramState> variants) { public GameStateProgram<P> compile(ResourceLocation name, SourceFile file, List<ProgramState> variants) {
WorldShader shader = new WorldShader(name, template, header) WorldShader shader = new WorldShader(name, template, header)
.setMainSource(file); .setMainSource(file);

View file

@ -62,7 +62,7 @@ public class FileResolution {
* Called after all files are loaded. If we can't find the file here, it doesn't exist. * Called after all files are loaded. If we can't find the file here, it doesn't exist.
* </p> * </p>
*/ */
void resolve(ISourceHolder sources) { void resolve(SourceHolder sources) {
try { try {
file = sources.findSource(fileLoc); file = sources.findSource(fileLoc);

View file

@ -28,7 +28,7 @@ public class Resolver {
/** /**
* Try and resolve all referenced source files, printing errors if any aren't found. * Try and resolve all referenced source files, printing errors if any aren't found.
*/ */
public void resolve(ISourceHolder sources) { public void resolve(SourceHolder sources) {
for (FileResolution resolution : resolutions.values()) { for (FileResolution resolution : resolutions.values()) {
resolution.resolve(sources); resolution.resolve(sources);
} }

View file

@ -17,7 +17,7 @@ import net.minecraft.resources.ResourceLocation;
/** /**
* The main object for loading and parsing source files. * The main object for loading and parsing source files.
*/ */
public class ShaderSources implements ISourceHolder { public class ShaderSources implements SourceHolder {
public static final String SHADER_DIR = "flywheel/shaders/"; public static final String SHADER_DIR = "flywheel/shaders/";
public static final ArrayList<String> EXTENSIONS = Lists.newArrayList(".vert", ".vsh", ".frag", ".fsh", ".glsl"); public static final ArrayList<String> EXTENSIONS = Lists.newArrayList(".vert", ".vsh", ".frag", ".fsh", ".glsl");

View file

@ -6,7 +6,7 @@ import net.minecraft.resources.ResourceLocation;
* A minimal source file lookup function. * A minimal source file lookup function.
*/ */
@FunctionalInterface @FunctionalInterface
public interface ISourceHolder { public interface SourceHolder {
SourceFile findSource(ResourceLocation name); SourceFile findSource(ResourceLocation name);
} }

View file

@ -6,6 +6,10 @@ import com.jozufozu.flywheel.backend.gl.GlTextureUnit;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
/**
* @deprecated TODO: Rework this to be more in-line/convertable with vanilla
*/
@Deprecated
public interface IRenderState { public interface IRenderState {
void bind(); void bind();

View file

@ -3,9 +3,9 @@ package com.jozufozu.flywheel.core;
import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.Flywheel;
import com.jozufozu.flywheel.backend.Backend; import com.jozufozu.flywheel.backend.Backend;
import com.jozufozu.flywheel.backend.SpecMetaRegistry; import com.jozufozu.flywheel.backend.SpecMetaRegistry;
import com.jozufozu.flywheel.backend.pipeline.IShaderPipeline; import com.jozufozu.flywheel.backend.pipeline.ShaderCompiler;
import com.jozufozu.flywheel.backend.pipeline.InstancingTemplate; import com.jozufozu.flywheel.backend.pipeline.InstancingTemplate;
import com.jozufozu.flywheel.backend.pipeline.WorldShaderPipeline; import com.jozufozu.flywheel.backend.pipeline.WorldShaderCompiler;
import com.jozufozu.flywheel.backend.source.FileResolution; import com.jozufozu.flywheel.backend.source.FileResolution;
import com.jozufozu.flywheel.backend.source.Resolver; import com.jozufozu.flywheel.backend.source.Resolver;
import com.jozufozu.flywheel.core.crumbling.CrumblingProgram; import com.jozufozu.flywheel.core.crumbling.CrumblingProgram;
@ -32,8 +32,8 @@ public class Contexts {
FileResolution crumblingBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.CRUMBLING, ".glsl")); FileResolution crumblingBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.CRUMBLING, ".glsl"));
FileResolution worldBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.WORLD, ".glsl")); FileResolution worldBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.WORLD, ".glsl"));
IShaderPipeline<CrumblingProgram> crumblingPipeline = new WorldShaderPipeline<>(CrumblingProgram::new, InstancingTemplate.INSTANCE, crumblingBuiltins); ShaderCompiler<CrumblingProgram> crumblingPipeline = new WorldShaderCompiler<>(CrumblingProgram::new, InstancingTemplate.INSTANCE, crumblingBuiltins);
IShaderPipeline<WorldProgram> worldPipeline = new WorldShaderPipeline<>(WorldProgram::new, InstancingTemplate.INSTANCE, worldBuiltins); ShaderCompiler<WorldProgram> worldPipeline = new WorldShaderCompiler<>(WorldProgram::new, InstancingTemplate.INSTANCE, worldBuiltins);
CRUMBLING = backend.register(WorldContext.builder(backend, Names.CRUMBLING).build(crumblingPipeline)); CRUMBLING = backend.register(WorldContext.builder(backend, Names.CRUMBLING).build(crumblingPipeline));
WORLD = backend.register(WorldContext.builder(backend, Names.WORLD).build(worldPipeline)); WORLD = backend.register(WorldContext.builder(backend, Names.WORLD).build(worldPipeline));

View file

@ -6,24 +6,24 @@ import java.util.function.Supplier;
import java.util.stream.Stream; import java.util.stream.Stream;
import com.jozufozu.flywheel.backend.Backend; import com.jozufozu.flywheel.backend.Backend;
import com.jozufozu.flywheel.backend.IShaderContext; import com.jozufozu.flywheel.backend.ShaderContext;
import com.jozufozu.flywheel.backend.material.MaterialSpec; import com.jozufozu.flywheel.backend.material.MaterialSpec;
import com.jozufozu.flywheel.backend.pipeline.IShaderPipeline; import com.jozufozu.flywheel.backend.pipeline.ShaderCompiler;
import com.jozufozu.flywheel.core.shader.IMultiProgram; import com.jozufozu.flywheel.core.shader.GameStateProgram;
import com.jozufozu.flywheel.core.shader.WorldProgram; import com.jozufozu.flywheel.core.shader.WorldProgram;
import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
public class WorldContext<P extends WorldProgram> implements IShaderContext<P> { public class WorldContext<P extends WorldProgram> implements ShaderContext<P> {
public final Backend backend; public final Backend backend;
protected final Map<ResourceLocation, IMultiProgram<P>> programs = new HashMap<>(); protected final Map<ResourceLocation, GameStateProgram<P>> programs = new HashMap<>();
protected final ResourceLocation name; protected final ResourceLocation name;
protected final Supplier<Stream<ResourceLocation>> specStream; protected final Supplier<Stream<ResourceLocation>> specStream;
public final IShaderPipeline<P> pipeline; public final ShaderCompiler<P> pipeline;
public WorldContext(Backend backend, ResourceLocation name, Supplier<Stream<ResourceLocation>> specStream, IShaderPipeline<P> pipeline) { public WorldContext(Backend backend, ResourceLocation name, Supplier<Stream<ResourceLocation>> specStream, ShaderCompiler<P> pipeline) {
this.backend = backend; this.backend = backend;
this.name = name; this.name = name;
this.specStream = specStream; this.specStream = specStream;
@ -61,7 +61,7 @@ public class WorldContext<P extends WorldProgram> implements IShaderContext<P> {
@Override @Override
public void delete() { public void delete() {
programs.values() programs.values()
.forEach(IMultiProgram::delete); .forEach(GameStateProgram::delete);
programs.clear(); programs.clear();
} }
@ -84,7 +84,7 @@ public class WorldContext<P extends WorldProgram> implements IShaderContext<P> {
return this; return this;
} }
public <P extends WorldProgram> WorldContext<P> build(IShaderPipeline<P> pipeline) { public <P extends WorldProgram> WorldContext<P> build(ShaderCompiler<P> pipeline) {
if (specStream == null) { if (specStream == null) {
specStream = () -> backend.allMaterials() specStream = () -> backend.allMaterials()
.stream() .stream()

View file

@ -1,11 +1,9 @@
package com.jozufozu.flywheel.core.materials; package com.jozufozu.flywheel.core.materials;
import org.lwjgl.system.MemoryUtil;
import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer;
import com.jozufozu.flywheel.backend.instancing.InstanceData; import com.jozufozu.flywheel.backend.instancing.InstanceData;
public abstract class BasicData extends InstanceData implements IFlatLight<BasicData> { public abstract class BasicData extends InstanceData implements FlatLight {
public byte blockLight; public byte blockLight;
public byte skyLight; public byte skyLight;

View file

@ -7,21 +7,19 @@ import com.jozufozu.flywheel.backend.instancing.InstanceData;
* if they wish to make use of Flywheel's provided light update methods. * if they wish to make use of Flywheel's provided light update methods.
* <p> * <p>
* This only covers flat lighting, smooth lighting is still TODO. * This only covers flat lighting, smooth lighting is still TODO.
*
* @param <D> The name of the class that implements this interface.
*/ */
public interface IFlatLight<D extends InstanceData & IFlatLight<D>> { public interface FlatLight {
/** /**
* @param blockLight An integer in the range [0, 15] representing the * @param blockLight An integer in the range [0, 15] representing the
* amount of block light this instance should receive. * amount of block light this instance should receive.
* @return <code>this</code> * @return <code>this</code>
*/ */
D setBlockLight(int blockLight); FlatLight setBlockLight(int blockLight);
/** /**
* @param skyLight An integer in the range [0, 15] representing the * @param skyLight An integer in the range [0, 15] representing the
* amount of sky light this instance should receive. * amount of sky light this instance should receive.
* @return <code>this</code> * @return <code>this</code>
*/ */
D setSkyLight(int skyLight); FlatLight setSkyLight(int skyLight);
} }

View file

@ -25,7 +25,7 @@ import net.minecraft.core.Direction;
import com.mojang.math.Vector3f; import com.mojang.math.Vector3f;
import net.minecraft.core.Vec3i; import net.minecraft.core.Vec3i;
public class BakedModelModel implements IModel { public class BakedModelModel implements Model {
// DOWN, UP, NORTH, SOUTH, WEST, EAST, null // DOWN, UP, NORTH, SOUTH, WEST, EAST, null
private static final Direction[] dirs; private static final Direction[] dirs;

View file

@ -2,8 +2,6 @@ package com.jozufozu.flywheel.core.model;
import java.util.Arrays; import java.util.Arrays;
import org.lwjgl.opengl.GL11;
import com.jozufozu.flywheel.backend.gl.attrib.VertexFormat; import com.jozufozu.flywheel.backend.gl.attrib.VertexFormat;
import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer;
import com.jozufozu.flywheel.core.Formats; import com.jozufozu.flywheel.core.Formats;
@ -25,7 +23,7 @@ import net.minecraft.core.BlockPos;
/** /**
* A model of a single block. * A model of a single block.
*/ */
public class BlockModel implements IModel { public class BlockModel implements Model {
private static final PoseStack IDENTITY = new PoseStack(); private static final PoseStack IDENTITY = new PoseStack();
private final BufferBuilderReader reader; private final BufferBuilderReader reader;

View file

@ -25,7 +25,7 @@ import com.jozufozu.flywheel.core.QuadConverter;
* assert model.size() == final - initial; * assert model.size() == final - initial;
* }</pre> * }</pre>
*/ */
public interface IModel { public interface Model {
/** /**
* Copy this model into the given buffer. * Copy this model into the given buffer.

View file

@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.gl.attrib.VertexFormat;
import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer;
import com.jozufozu.flywheel.core.Formats; import com.jozufozu.flywheel.core.Formats;
public class ModelPart implements IModel { public class ModelPart implements Model {
private final List<PartBuilder.CuboidBuilder> cuboids; private final List<PartBuilder.CuboidBuilder> cuboids;
private int vertices; private int vertices;

View file

@ -12,7 +12,7 @@ import net.minecraft.client.renderer.RenderType;
import net.minecraft.world.level.BlockAndTintGetter; import net.minecraft.world.level.BlockAndTintGetter;
import net.minecraft.world.level.levelgen.structure.templatesystem.StructureTemplate; import net.minecraft.world.level.levelgen.structure.templatesystem.StructureTemplate;
public class WorldModel implements IModel { public class WorldModel implements Model {
private final BufferBuilderReader reader; private final BufferBuilderReader reader;

View file

@ -2,13 +2,14 @@ package com.jozufozu.flywheel.core.shader;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.Supplier;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.jozufozu.flywheel.backend.gl.shader.GlProgram; import com.jozufozu.flywheel.backend.gl.shader.GlProgram;
import com.jozufozu.flywheel.core.shader.spec.IGameStateCondition; import com.jozufozu.flywheel.core.shader.spec.IGameStateCondition;
import com.jozufozu.flywheel.util.Pair; import com.jozufozu.flywheel.util.Pair;
public class GameStateProgram<P extends GlProgram> implements IMultiProgram<P> { public class GameStateProgram<P extends GlProgram> implements Supplier<P> {
private final List<Pair<IGameStateCondition, P>> variants; private final List<Pair<IGameStateCondition, P>> variants;
private final P fallback; private final P fallback;
@ -18,6 +19,9 @@ public class GameStateProgram<P extends GlProgram> implements IMultiProgram<P> {
this.fallback = fallback; this.fallback = fallback;
} }
/**
* Get the shader program most suited for the current game state.
*/
@Override @Override
public P get() { public P get() {
for (Pair<IGameStateCondition, P> variant : variants) { for (Pair<IGameStateCondition, P> variant : variants) {
@ -28,7 +32,9 @@ public class GameStateProgram<P extends GlProgram> implements IMultiProgram<P> {
return fallback; return fallback;
} }
@Override /**
* Delete all associated programs.
*/
public void delete() { public void delete() {
for (Pair<IGameStateCondition, P> variant : variants) { for (Pair<IGameStateCondition, P> variant : variants) {
variant.getSecond() variant.getSecond()
@ -55,7 +61,7 @@ public class GameStateProgram<P extends GlProgram> implements IMultiProgram<P> {
return this; return this;
} }
public IMultiProgram<P> build() { public GameStateProgram<P> build() {
return new GameStateProgram<>(ImmutableList.copyOf(variants), fallback); return new GameStateProgram<>(ImmutableList.copyOf(variants), fallback);
} }
} }

View file

@ -1,26 +0,0 @@
package com.jozufozu.flywheel.core.shader;
import java.util.function.Supplier;
import com.jozufozu.flywheel.backend.gl.shader.GlProgram;
/**
* Encapsulates any number of shader programs for use in similar contexts.
* Allows the implementor to choose which shader program to use based on arbitrary state.
*
* @param <P>
*/
public interface IMultiProgram<P extends GlProgram> extends Supplier<P> {
/**
* Get the shader program most suited for the current game state.
*
* @return The one true program.
*/
P get();
/**
* Delete all shader programs encapsulated by your implementation.
*/
void delete();
}

View file

@ -1,6 +1,6 @@
package com.jozufozu.flywheel.vanilla; package com.jozufozu.flywheel.vanilla;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.Materials;
@ -14,7 +14,7 @@ import net.minecraft.util.Mth;
import com.mojang.math.Quaternion; import com.mojang.math.Quaternion;
import com.mojang.math.Vector3f; import com.mojang.math.Vector3f;
public class BellInstance extends TileEntityInstance<BellBlockEntity> implements IDynamicInstance { public class BellInstance extends TileEntityInstance<BellBlockEntity> implements DynamicInstance {
private final OrientedData bell; private final OrientedData bell;

View file

@ -4,7 +4,7 @@ import java.util.Calendar;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.backend.state.TextureRenderState; import com.jozufozu.flywheel.backend.state.TextureRenderState;
@ -29,7 +29,7 @@ import net.minecraft.world.level.block.DoubleBlockCombiner;
import com.mojang.math.Quaternion; import com.mojang.math.Quaternion;
import com.mojang.math.Vector3f; import com.mojang.math.Vector3f;
public class ChestInstance<T extends BlockEntity & LidBlockEntity> extends TileEntityInstance<T> implements IDynamicInstance { public class ChestInstance<T extends BlockEntity & LidBlockEntity> extends TileEntityInstance<T> implements DynamicInstance {
private final MatrixTransformStack stack = new MatrixTransformStack(); private final MatrixTransformStack stack = new MatrixTransformStack();
private final OrientedData body; private final OrientedData body;

View file

@ -1,13 +1,13 @@
package com.jozufozu.flywheel.vanilla; package com.jozufozu.flywheel.vanilla;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.ITickableInstance; import com.jozufozu.flywheel.backend.instancing.TickableInstance;
import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance; import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.backend.state.TextureRenderState; import com.jozufozu.flywheel.backend.state.TextureRenderState;
import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.Materials;
import com.jozufozu.flywheel.core.materials.model.ModelData; import com.jozufozu.flywheel.core.materials.model.ModelData;
import com.jozufozu.flywheel.core.model.IModel; import com.jozufozu.flywheel.core.model.Model;
import com.jozufozu.flywheel.core.model.ModelPart; import com.jozufozu.flywheel.core.model.ModelPart;
import com.jozufozu.flywheel.util.AnimationTickHolder; import com.jozufozu.flywheel.util.AnimationTickHolder;
import com.jozufozu.flywheel.util.transform.MatrixTransformStack; import com.jozufozu.flywheel.util.transform.MatrixTransformStack;
@ -21,7 +21,7 @@ import net.minecraft.util.Mth;
import net.minecraft.world.phys.Vec3; import net.minecraft.world.phys.Vec3;
import com.mojang.math.Vector3f; import com.mojang.math.Vector3f;
public class MinecartInstance<T extends AbstractMinecart> extends EntityInstance<T> implements IDynamicInstance, ITickableInstance { public class MinecartInstance<T extends AbstractMinecart> extends EntityInstance<T> implements DynamicInstance, TickableInstance {
private static final ResourceLocation MINECART_LOCATION = new ResourceLocation("textures/entity/minecart.png"); private static final ResourceLocation MINECART_LOCATION = new ResourceLocation("textures/entity/minecart.png");
@ -153,7 +153,7 @@ public class MinecartInstance<T extends AbstractMinecart> extends EntityInstance
.createInstance(); .createInstance();
} }
private IModel getBodyModel() { private Model getBodyModel() {
int y = -3; int y = -3;
return ModelPart.builder(64, 32) return ModelPart.builder(64, 32)
.cuboid().invertYZ().start(-10, -8, -y).size(20, 16, 2).textureOffset(0, 10).rotateX(((float)Math.PI / 2F)).endCuboid() .cuboid().invertYZ().start(-10, -8, -y).size(20, 16, 2).textureOffset(0, 10).rotateX(((float)Math.PI / 2F)).endCuboid()

View file

@ -1,6 +1,6 @@
package com.jozufozu.flywheel.vanilla; package com.jozufozu.flywheel.vanilla;
import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; import com.jozufozu.flywheel.backend.instancing.DynamicInstance;
import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance;
import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.material.MaterialManager;
import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.Materials;
@ -18,7 +18,7 @@ import net.minecraft.core.Direction;
import com.mojang.math.Quaternion; import com.mojang.math.Quaternion;
import com.mojang.math.Vector3f; import com.mojang.math.Vector3f;
public class ShulkerBoxInstance extends TileEntityInstance<ShulkerBoxBlockEntity> implements IDynamicInstance { public class ShulkerBoxInstance extends TileEntityInstance<ShulkerBoxBlockEntity> implements DynamicInstance {
private final TextureAtlasSprite texture; private final TextureAtlasSprite texture;