Skip to content

Commit

Permalink
Merge pull request #702 from zyxkad/p2p-feature
Browse files Browse the repository at this point in the history
add CC Networking Cable p2p tunnel
  • Loading branch information
zyxkad authored Jan 21, 2025
2 parents 016c6c2 + 2b2f9d1 commit 708c1c7
Show file tree
Hide file tree
Showing 22 changed files with 310 additions and 33 deletions.
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(() -> {
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
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

0 comments on commit 708c1c7

Please sign in to comment.