Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add CC Networking Cable p2p tunnel #702

Merged
merged 9 commits into from
Jan 21, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
// 1.19.2 2024-05-28T14:53:16.653667 Tags for minecraft:item
// 1.19.2 2025-01-20T07:59:27.474151 Tags for minecraft:item
de4b4f45ec18b2b1f0db1c36882981042e20ee23 data/advancedperipherals/tags/items/p2p_attunements/cable_p2p_tunnel.json
72eba3b11f69e16c87488f7c4ba7cfdad42c378e data/advancedperipherals/tags/items/smart_glasses.json
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
// 1.19.2 2025-01-16T15:59:34.693839 Languages: en_us
d0fe3ab5a88d6b925369860038c76f23d9910143 assets/advancedperipherals/lang/en_us.json
// 1.19.2 2025-01-20T07:50:09.44057 Languages: en_us
ebf2194b8fece940adb61f1ae317f68799bd498f assets/advancedperipherals/lang/en_us.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
"block.advancedperipherals.rs_bridge": "RS Bridge",
"curios.identifier.glasses": "Glasses",
"entity.minecraft.villager.advancedperipherals.computer_scientist": "Computer Scientist",
"item.advancedperipherals.cable_p2p_tunnel": "Cable P2P Tunnel",
"item.advancedperipherals.chunk_controller": "Chunk Controller",
"item.advancedperipherals.computer_tool": "Computer Tool",
"item.advancedperipherals.end_automata_core": "End Automata Core",
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"values": [
"computercraft:cable",
"computercraft:wired_modem",
"computercraft:wired_modem_full"
]
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package de.srendi.advancedperipherals;

import de.srendi.advancedperipherals.common.addons.APAddons;
import de.srendi.advancedperipherals.common.addons.ae2.AE2Registries;
import de.srendi.advancedperipherals.common.configuration.APConfig;
import de.srendi.advancedperipherals.common.network.APNetworking;
import de.srendi.advancedperipherals.common.setup.APRegistration;
Expand All @@ -11,6 +12,7 @@
import net.minecraftforge.fml.ModLoadingContext;
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
import net.minecraftforge.fml.event.lifecycle.FMLLoadCompleteEvent;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
Expand All @@ -35,6 +37,7 @@ public AdvancedPeripherals() {
APConfig.register(ModLoadingContext.get());

modBus.addListener(this::commonSetup);
modBus.addListener(this::onLoadComplete);
APRegistration.register();
MinecraftForge.EVENT_BUS.register(this);
new APAddons();
Expand Down Expand Up @@ -67,4 +70,11 @@ public void commonSetup(FMLCommonSetupEvent event) {
});
}

public void onLoadComplete(FMLLoadCompleteEvent event) {
event.enqueueWork(() -> {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we maybe want to put this into the APAddons class or into the Integration class direclty

Do we even need a Integration class if the run method is not used? Maybe we want to re-organize that

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was trying to do that in Integration.run(), but Integration runs before items get registered...
I'll move them to Registries

Copy link
Member

@SirEndii SirEndii Jan 21, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That is weird
Should happen after item registration

if (APAddons.appliedEnergisticsLoaded) {
AE2Registries.finishRegister();
}
});
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,38 +23,51 @@
@Mod.EventBusSubscriber(modid = AdvancedPeripherals.MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD)
public class APAddons {

public static final String CURIOS_MODID = "curios";
public static final String REFINEDSTORAGE_MODID = "refinedstorage";
public static final String AE_ADDITIONS_MODID = "ae2additions";
public static final String AE_THINGS_MODID = "ae2things";
public static final String APPLIEDENERGISTICS_MODID = "ae2";
public static final String MEKANISM_MODID = "mekanism";
public static final String AE_ADDITIONS_MODID = "ae2additions";
public static final String APP_MEKANISTICS_MODID = "appmek";
public static final String BOTANIA_MODID = "botania";
public static final String CREATE_MODID = "create";
public static final String CURIOS_MODID = "curios";
public static final String DIMSTORAGE_MODID = "dimstorage";
public static final String MEKANISM_MODID = "mekanism";
public static final String POWAH_MODID = "powah";
public static final String REFINEDSTORAGE_MODID = "refinedstorage";
public static final String VALKYRIEN_SKIES_MODID = "valkyrienskies";

public static boolean curiosLoaded;
public static boolean refinedStorageLoaded;
public static boolean aeAdditionsLoaded;
public static boolean aeThingsLoaded;
public static boolean appMekLoaded;
public static boolean appliedEnergisticsLoaded;
public static boolean botaniaLoaded;
public static boolean createLoaded;
public static boolean curiosLoaded;
public static boolean dimstorageLoaded;
public static boolean mekanismLoaded;
public static boolean aeAdditionsLoaded;
public static boolean appMekLoaded;
public static boolean powahLoaded;
public static boolean refinedStorageLoaded;
public static boolean vs2Loaded;

// Use static so these checks run as early as possible, so we can use them for our registries
static {
ModList modList = ModList.get();
curiosLoaded = modList.isLoaded(CURIOS_MODID);
refinedStorageLoaded = modList.isLoaded(REFINEDSTORAGE_MODID);
appliedEnergisticsLoaded = modList.isLoaded(APPLIEDENERGISTICS_MODID);
mekanismLoaded = modList.isLoaded(MEKANISM_MODID);
aeThingsLoaded = modList.isLoaded(AE_THINGS_MODID);
aeAdditionsLoaded = modList.isLoaded(AE_ADDITIONS_MODID);
aeThingsLoaded = modList.isLoaded(AE_THINGS_MODID);
appMekLoaded = modList.isLoaded(APP_MEKANISTICS_MODID);
appliedEnergisticsLoaded = modList.isLoaded(APPLIEDENERGISTICS_MODID);
botaniaLoaded = modList.isLoaded(BOTANIA_MODID);
createLoaded = modList.isLoaded(CREATE_MODID);
curiosLoaded = modList.isLoaded(CURIOS_MODID);
dimstorageLoaded = modList.isLoaded(DIMSTORAGE_MODID);
mekanismLoaded = modList.isLoaded(MEKANISM_MODID);
powahLoaded = modList.isLoaded(POWAH_MODID);
refinedStorageLoaded = modList.isLoaded(REFINEDSTORAGE_MODID);
vs2Loaded = modList.isLoaded(VALKYRIEN_SKIES_MODID);

if (refinedStorageLoaded)
if (refinedStorageLoaded) {
RefinedStorage.instance = new RefinedStorage();
}
}

@SubscribeEvent
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.features.P2PTunnelAttunement;
import appeng.api.parts.IPart;
import appeng.api.parts.IPartItem;
import appeng.api.parts.PartModels;
import appeng.items.parts.PartItem;
import appeng.items.parts.PartModelsHelper;
import dan200.computercraft.shared.Registry.ModItems;
import de.srendi.advancedperipherals.common.setup.APRegistration;
import net.minecraft.data.tags.TagsProvider;
import net.minecraft.tags.TagKey;
import net.minecraft.world.item.Item;
import net.minecraftforge.registries.RegistryObject;

import java.util.function.Function;

public final class AE2Registries {
private AE2Registries() {}

public static final RegistryObject<PartItem<WiredCableP2PTunnelPart>> CABLE_P2P_TUNNEL = registerPart("cable_p2p_tunnel", WiredCableP2PTunnelPart.class, WiredCableP2PTunnelPart::new);

private static <T extends IPart> RegistryObject<PartItem<T>> registerPart(String id, Class<T> clazz, Function<IPartItem<T>, T> factory) {
PartModels.registerModels(PartModelsHelper.createModels(clazz));
return APRegistration.ITEMS.register(id, () -> new PartItem<>(new Item.Properties(), clazz, factory));
}

public static void finishRegister() {
P2PTunnelAttunement.registerAttunementTag(CABLE_P2P_TUNNEL.get());
}

public static TagKey<Item> getCableP2PTag() {
return P2PTunnelAttunement.getAttunementTag(CABLE_P2P_TUNNEL.get());
}

public static void registerTags(Function<TagKey<Item>, TagsProvider.TagAppender<Item>> tagger) {
tagger.apply(getCableP2PTag())
.add(ModItems.CABLE.get())
.add(ModItems.WIRED_MODEM.get())
.add(ModItems.WIRED_MODEM_FULL.get());
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package de.srendi.advancedperipherals.common.addons.appliedenergistics;
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.crafting.IPatternDetails;
import appeng.api.inventories.InternalInventory;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package de.srendi.advancedperipherals.common.addons.appliedenergistics;
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.networking.IGrid;
import appeng.api.networking.IGridNode;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package de.srendi.advancedperipherals.common.addons.appliedenergistics;
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.networking.IGridNode;
import appeng.api.networking.IGridNodeListener;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package de.srendi.advancedperipherals.common.addons.appliedenergistics;
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.config.Actionable;
import appeng.api.networking.security.IActionSource;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package de.srendi.advancedperipherals.common.addons.appliedenergistics;
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.config.Actionable;
import appeng.api.networking.security.IActionSource;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,174 @@
package de.srendi.advancedperipherals.common.addons.ae2;

import appeng.api.networking.IGridNodeListener;
import appeng.api.parts.IPartItem;
import appeng.api.parts.IPartModel;
import appeng.items.parts.PartModels;
import appeng.parts.p2p.CapabilityP2PTunnelPart;
import appeng.parts.p2p.P2PModels;
import dan200.computercraft.api.ComputerCraftAPI;
import dan200.computercraft.api.network.wired.IWiredElement;
import dan200.computercraft.api.network.wired.IWiredNetworkChange;
import dan200.computercraft.api.network.wired.IWiredNode;
import dan200.computercraft.shared.Capabilities;
import de.srendi.advancedperipherals.AdvancedPeripherals;
import net.minecraft.core.BlockPos;
import net.minecraft.world.level.BlockGetter;
import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.phys.Vec3;

import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import javax.annotation.Nonnull;

public class WiredCableP2PTunnelPart extends CapabilityP2PTunnelPart<WiredCableP2PTunnelPart, IWiredElement> {
private static final P2PModels MODELS = new P2PModels(AdvancedPeripherals.getRL("part/p2p/p2p_tunnel_cable"));

private final IWiredElement element = new P2PWiredElement();
private final IWiredElement outElement = new P2PWiredElement();
private final IWiredNode node = this.element.getNode();
private Set<WiredCableP2PTunnelPart> connected = new HashSet<>();
private boolean activated = false;

public WiredCableP2PTunnelPart(IPartItem<?> partItem) {
super(partItem, Capabilities.CAPABILITY_WIRED_ELEMENT);
this.inputHandler = outElement;
this.outputHandler = outElement;
this.emptyHandler = null; // should never used
}

@PartModels
public static List<IPartModel> getModels() {
return MODELS.getModels();
}

@Override
public IPartModel getStaticModels() {
return MODELS.getModel(this.isPowered(), this.isActive());
}

@Override
public void onTunnelConfigChange() {
super.onTunnelConfigChange();
this.connectionsChanged();
}

@Override
public void onTunnelNetworkChange() {
super.onTunnelNetworkChange();
this.connectionsChanged();
}

protected void connectionsChanged() {
if (this.isClientSide()) {
return;
}
if (!this.isActive()) {
return;
}
if (!this.activated) {
this.activated = true;
this.node.connectTo(this.outElement.getNode());
}

Stream<WiredCableP2PTunnelPart> nodeStream = this.getOutputStream().filter(out -> out != this);
WiredCableP2PTunnelPart in = this.getInput();
if (in != null && in != this) {
nodeStream = Stream.concat(nodeStream, Stream.of(in));
}
Set<WiredCableP2PTunnelPart> nodes = nodeStream.collect(Collectors.toCollection(HashSet::new));

for (WiredCableP2PTunnelPart part : this.connected.stream().filter(n -> !nodes.contains(n)).collect(Collectors.toList())) {
if (part.connected.contains(this)) {
this.node.disconnectFrom(part.node);
part.connected.remove(this);
}
this.connected.remove(part);
}

for (WiredCableP2PTunnelPart part : nodes) {
if (!this.connected.contains(part)) {
this.node.connectTo(part.node);
this.connected.add(part);
part.connected.add(this);
}
}
}

@Override
protected void onMainNodeStateChanged(IGridNodeListener.State reason) {
super.onMainNodeStateChanged(reason);
if (reason == IGridNodeListener.State.GRID_BOOT) {
return;
}
if (this.isActive()) {
if (!this.getMainNode().hasGridBooted()) {
return;
}
this.connectionsChanged();
this.refreshConnection();
} else if (this.activated) {
this.activated = false;
this.node.remove();
this.connected.clear();
}
}

protected BlockPos getFacingPos() {
return this.getHost().getLocation().getPos().relative(this.getSide());
}

protected void refreshConnection() {
BlockEntity cable = this.getLevel().getBlockEntity(this.getFacingPos());
IWiredElement elem = cable == null ? null : cable.getCapability(Capabilities.CAPABILITY_WIRED_ELEMENT, this.getSide().getOpposite()).orElse(null);
if (elem == null) {
return;
}
elem.getNode().connectTo(this.outElement.getNode());
}

@Override
public void onNeighborChanged(BlockGetter level, BlockPos pos, BlockPos neighbor) {
if (!this.getFacingPos().equals(neighbor)) {
return;
}
if (this.activated) {
this.refreshConnection();
}
}

private class P2PWiredElement implements IWiredElement {
private final IWiredNode node = ComputerCraftAPI.createWiredNodeForElement(this);

@Nonnull
@Override
public IWiredNode getNode() {
return node;
}

@Nonnull
@Override
public String getSenderID() {
return "p2p";
}

@Nonnull
@Override
zyxkad marked this conversation as resolved.
Show resolved Hide resolved
public Level getLevel() {
return WiredCableP2PTunnelPart.this.getLevel();
}

@Nonnull
@Override
public Vec3 getPosition() {
return Vec3.atCenterOf(WiredCableP2PTunnelPart.this.getBlockEntity().getBlockPos());
}

@Override
public void networkChanged(IWiredNetworkChange change) {}
}
}
Loading