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

Release v2.0.0-milestone.3.5 #514

Merged
merged 71 commits into from
Apr 4, 2024
Merged
Changes from 9 commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
867d129
Merge pull request #496 from refinedmods/main
raoulvdberge Mar 16, 2024
b4490f2
feat: crowdin config file
raoulvdberge Mar 16, 2024
0b7f4cd
Merge pull request #497 from refinedmods/feat/GH-210/crowdin
raoulvdberge Mar 16, 2024
617f008
fix: crowdin commit message and pr label
raoulvdberge Mar 16, 2024
2ce6804
Merge pull request #499 from refinedmods/fix/GH-210/crowdincommits
raoulvdberge Mar 16, 2024
8ac58fa
chore: update translation Chinese Simplified from crowdin
raoulvdberge Mar 16, 2024
15de5ae
chore: update translation French from crowdin
raoulvdberge Mar 16, 2024
f723a5d
chore: update translation Spanish from crowdin
raoulvdberge Mar 16, 2024
60e1a9d
chore: update translation German from crowdin
raoulvdberge Mar 16, 2024
3e2599f
chore: update translation Polish from crowdin
raoulvdberge Mar 16, 2024
d63af11
chore: update translation Russian from crowdin
raoulvdberge Mar 16, 2024
ca5bc15
chore: update translation Portuguese, Brazilian from crowdin
raoulvdberge Mar 16, 2024
a401a3f
Merge pull request #500 from refinedmods/crowdin-translations
raoulvdberge Mar 16, 2024
4cfa4c1
chore: update translation Hungarian from crowdin
raoulvdberge Mar 16, 2024
4c58c4c
Merge pull request #501 from refinedmods/crowdin-translations
raoulvdberge Mar 16, 2024
9e4a0f4
docs: crowdin badge and link
raoulvdberge Mar 16, 2024
5944813
fix: wireless grid name not being correct in gui
raoulvdberge Mar 16, 2024
44bc06e
fix: minecraft version in issue template
raoulvdberge Mar 16, 2024
ea98e46
Merge pull request #504 from refinedmods/fix/GH-502/menutitle
raoulvdberge Mar 16, 2024
ea2c926
chore: update translation French from crowdin
raoulvdberge Mar 17, 2024
6637ba8
chore: update translation German from crowdin
raoulvdberge Mar 17, 2024
d468362
chore: update translation Italian from crowdin
raoulvdberge Mar 17, 2024
9f85777
chore: update translation Japanese from crowdin
raoulvdberge Mar 17, 2024
128cf80
chore: update translation Korean from crowdin
raoulvdberge Mar 17, 2024
fd4a30d
chore: update translation Dutch from crowdin
raoulvdberge Mar 17, 2024
c7b2891
chore: update translation Chinese Traditional from crowdin
raoulvdberge Mar 17, 2024
6249bbb
chore: update translation Indonesian from crowdin
raoulvdberge Mar 17, 2024
e161117
Merge pull request #505 from refinedmods/crowdin-translations
raoulvdberge Mar 17, 2024
6f768d8
chore: update translation Polish from crowdin
raoulvdberge Mar 18, 2024
0f950d2
chore: update translation Portuguese, Brazilian from crowdin
raoulvdberge Mar 18, 2024
4b3e59d
chore: update translation Indonesian from crowdin
raoulvdberge Mar 18, 2024
42bc76d
chore: update translation French from crowdin
raoulvdberge Mar 19, 2024
adc5a4f
chore: update translation Polish from crowdin
raoulvdberge Mar 19, 2024
1ed70f9
Merge pull request #506 from refinedmods/crowdin-translations
raoulvdberge Mar 19, 2024
1c9d66d
refactor: move network components to their related package instead of…
raoulvdberge Mar 16, 2024
4a57de7
feat: security primitives
raoulvdberge Mar 16, 2024
95f14db
docs: note about crowdin
raoulvdberge Mar 17, 2024
d47cae7
feat: security card item
raoulvdberge Mar 17, 2024
5d5b370
feat: security card screen
raoulvdberge Mar 23, 2024
52bbb3a
feat: security security logic
raoulvdberge Mar 31, 2024
c071fd6
feat: fallback security card
raoulvdberge Mar 31, 2024
3cabe48
Merge pull request #509 from refinedmods/feat/GH-86/security-card
raoulvdberge Mar 31, 2024
6753b30
refactor: remove duplicated mod name translation
raoulvdberge Mar 31, 2024
567ddaf
chore: add intellij word dictionary
raoulvdberge Apr 1, 2024
2a20052
chore: add intellij project icon
raoulvdberge Apr 1, 2024
cd941d7
chore: reduce logging level
raoulvdberge Apr 1, 2024
be52b74
refactor: remove default registry values
raoulvdberge Apr 1, 2024
f0da2e0
docs: add note about grid view settings that became global to changelog
raoulvdberge Apr 1, 2024
8d6f354
refactor: security card client communications should use platform per…
raoulvdberge Apr 1, 2024
3def5dd
chore: sonar issues
raoulvdberge Apr 1, 2024
8ce67c7
Merge pull request #510 from refinedmods/feat/GH-86/security-card-cle…
raoulvdberge Apr 1, 2024
4ae1b45
fix: security card not updating while gui is open because slots were …
raoulvdberge Apr 1, 2024
7975d13
feat: security manager block
raoulvdberge Apr 1, 2024
96f67d1
feat: security network component logic and security card api
raoulvdberge Apr 2, 2024
8f18bd5
feat: security manager screen
raoulvdberge Apr 2, 2024
0278b41
feat: security card energy usage
raoulvdberge Apr 2, 2024
981dd66
feat: security network component logic pt 2
raoulvdberge Apr 2, 2024
31566d3
ci: exclude rei properly from sonar duplication checking
raoulvdberge Apr 3, 2024
5334b8d
Merge pull request #511 from refinedmods/feat/GH-90/security-manager
raoulvdberge Apr 3, 2024
77366f2
feat: permission checking
raoulvdberge Apr 3, 2024
66afd6a
feat: open permission checking
raoulvdberge Apr 4, 2024
411e2df
feat: insert and extract permission checking
raoulvdberge Apr 4, 2024
43eae90
feat: build permission checking
raoulvdberge Apr 4, 2024
b87adbe
fix: activeness checking on the security manager
raoulvdberge Apr 4, 2024
295ec2f
fix: confusing directionality on security manager
raoulvdberge Apr 4, 2024
a60e8e9
fix: slight desync when transferring fallback card
raoulvdberge Apr 4, 2024
04f0cb4
chore: sonar issues
raoulvdberge Apr 4, 2024
9b32e83
fix: forgotten build check for item storage and fluid storage blocks
raoulvdberge Apr 4, 2024
147a90e
fix: being able to bypass security rules with rotating or dismantling
raoulvdberge Apr 4, 2024
9bf2e5e
Merge pull request #513 from refinedmods/feat/GH-90/permission-checks
raoulvdberge Apr 4, 2024
6181a47
chore: prepare release v2.0.0-milestone.3.5
raoulvdberge Apr 4, 2024
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
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -11,6 +11,8 @@ eclipse/
*.ipr
*.iws
.idea/
!.idea/dictionaries/refinedstorage2.xml
!.idea/icon.png
out/
/bin/
logs/
8 changes: 8 additions & 0 deletions .idea/dictionaries/refinedstorage2.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Binary file added .idea/icon.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -19,6 +19,7 @@ to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
- The binding of a Security Card can now be cleared.
- The Security Card tooltip and GUI now show whether the permission has been touched/changed in any way.
- A global (fallback) permission set for a network can be defined using the Fallback Security Card instead of using an "unbound" Security Card.
- Smooth scrolling, screen size and max row stretch are no longer Grid-specific settings, but are now global settings.

### Fixed

Original file line number Diff line number Diff line change
@@ -31,7 +31,7 @@ public void addWatcher(
attach(registration, storageChannel, false);
}
watchers.put(watcher, registration);
LOGGER.info("Added watcher {}, new count is {}", watcher, watchers.size());
LOGGER.debug("Added watcher {}, new count is {}", watcher, watchers.size());
}

@Override
@@ -57,7 +57,7 @@ private void attach(
final StorageChannel storageChannel,
final boolean replay
) {
LOGGER.info("Attaching {} to {}", registration, storageChannel);
LOGGER.debug("Attaching {} to {}", registration, storageChannel);
registration.attach(storageChannel, replay);
}

@@ -71,17 +71,17 @@ public void removeWatcher(final GridWatcher watcher, @Nullable final StorageChan
detach(registration, storageChannel);
}
watchers.remove(watcher);
LOGGER.info("Removed watcher {}, remaining {}", watcher, watchers.size());
LOGGER.debug("Removed watcher {}, remaining {}", watcher, watchers.size());
}

@Override
public void detachAll(final StorageChannel storageChannel) {
LOGGER.info("Detaching {} watchers", watchers.size());
LOGGER.debug("Detaching {} watchers", watchers.size());
watchers.values().forEach(watcher -> detach(watcher, storageChannel));
}

private void detach(final GridWatcherRegistration registration, final StorageChannel storageChannel) {
LOGGER.info("Detaching {} from {}", registration, storageChannel);
LOGGER.debug("Detaching {} from {}", registration, storageChannel);
registration.detach(storageChannel);
}

Original file line number Diff line number Diff line change
@@ -21,11 +21,6 @@ public interface PlatformRegistry<T> {
*/
void register(ResourceLocation id, T value);

/**
* @return whether if there is any other value, ignoring any default value
*/
boolean isEmpty();

/**
* @param value the value
* @return the id of the value, if present
@@ -38,28 +33,14 @@ public interface PlatformRegistry<T> {
*/
Optional<T> get(ResourceLocation id);

/**
* @return the default value
*/
T getDefault();

/**
* @return an unmodifiable list of all values
*/
List<T> getAll();

/**
* Returns the next value in the ordered list.
* If the value is not found, it will return the default value.
*
* @param value the given value
* @return the next value after the given value
*/
T next(T value);

/**
* Returns the next value in the ordered list.
* If the value is not found, it will the default value.
* If the value is not found, it will return the first value.
* If the value is the last value in the ordered list, it will return null.
*
* @param value the given value
Original file line number Diff line number Diff line change
@@ -10,6 +10,7 @@
import com.refinedmods.refinedstorage2.platform.common.detector.DetectorScreen;
import com.refinedmods.refinedstorage2.platform.common.exporter.ExporterScreen;
import com.refinedmods.refinedstorage2.platform.common.grid.GridContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.grid.NoopGridSynchronizer;
import com.refinedmods.refinedstorage2.platform.common.grid.WirelessGridContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.grid.screen.CraftingGridScreen;
import com.refinedmods.refinedstorage2.platform.common.grid.screen.GridScreen;
@@ -48,6 +49,13 @@
import static com.refinedmods.refinedstorage2.platform.common.util.IdentifierUtil.createIdentifier;

public abstract class AbstractClientModInitializer {
protected static void registerBaseGridSynchronizer() {
PlatformApi.INSTANCE.getGridSynchronizerRegistry().register(
createIdentifier("off"),
NoopGridSynchronizer.INSTANCE
);
}

protected static void registerScreens(final ScreenRegistration registration) {
registration.register(Menus.INSTANCE.getDiskDrive(), DiskDriveScreen::new);
registration.register(Menus.INSTANCE.getGrid(), GridScreen<GridContainerMenu>::new);
Original file line number Diff line number Diff line change
@@ -43,7 +43,6 @@
import com.refinedmods.refinedstorage2.platform.common.grid.GridBlockEntity;
import com.refinedmods.refinedstorage2.platform.common.grid.GridContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.grid.WirelessGridContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.grid.WirelessGridItem;
import com.refinedmods.refinedstorage2.platform.common.iface.InterfaceBlock;
import com.refinedmods.refinedstorage2.platform.common.iface.InterfaceBlockEntity;
import com.refinedmods.refinedstorage2.platform.common.iface.InterfaceContainerMenu;
@@ -57,9 +56,7 @@
import com.refinedmods.refinedstorage2.platform.common.networking.NetworkTransmitterContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.security.BuiltinPermission;
import com.refinedmods.refinedstorage2.platform.common.security.FallbackSecurityCardContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.security.FallbackSecurityCardItem;
import com.refinedmods.refinedstorage2.platform.common.security.SecurityCardContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.security.SecurityCardItem;
import com.refinedmods.refinedstorage2.platform.common.storage.FluidStorageType;
import com.refinedmods.refinedstorage2.platform.common.storage.ItemStorageType;
import com.refinedmods.refinedstorage2.platform.common.storage.StorageTypes;
@@ -71,7 +68,6 @@
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.AbstractPortableGridBlockEntity;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridBlock;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridBlockContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridBlockItem;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridItemContainerMenu;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridLootItemFunction;
import com.refinedmods.refinedstorage2.platform.common.storage.portablegrid.PortableGridType;
@@ -98,6 +94,7 @@
import com.refinedmods.refinedstorage2.platform.common.support.SimpleItem;
import com.refinedmods.refinedstorage2.platform.common.support.energy.EnergyLootItemFunction;
import com.refinedmods.refinedstorage2.platform.common.support.network.NetworkNodeContainerBlockEntityImpl;
import com.refinedmods.refinedstorage2.platform.common.support.network.bounditem.InventorySlotReferenceFactory;
import com.refinedmods.refinedstorage2.platform.common.support.network.component.PlatformStorageNetworkComponent;
import com.refinedmods.refinedstorage2.platform.common.support.resource.FluidResourceFactory;
import com.refinedmods.refinedstorage2.platform.common.support.resource.ResourceTypes;
@@ -136,7 +133,6 @@
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.CRAFTING_GRID;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.CREATIVE_CONTROLLER;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.CREATIVE_PORTABLE_GRID;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.CREATIVE_WIRELESS_GRID;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.DESTRUCTION_CORE;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.DESTRUCTOR;
import static com.refinedmods.refinedstorage2.platform.common.content.ContentIds.DETECTOR;
@@ -175,12 +171,13 @@
import static com.refinedmods.refinedstorage2.platform.common.util.IdentifierUtil.createIdentifier;

public abstract class AbstractModInitializer {
private static final String ITEM_REGISTRY_KEY = "item";
private static final String FLUID_REGISTRY_KEY = "fluid";

protected final void initializePlatformApi() {
((PlatformApiProxy) PlatformApi.INSTANCE).setDelegate(new PlatformApiImpl());
registerAdditionalStorageTypes();
registerAdditionalResourceTypes();
registerStorageTypes();
registerResourceTypes();
registerAdditionalResourceFactories();
registerDestructorStrategyFactories();
registerConstructorStrategyFactories();
@@ -189,16 +186,25 @@ protected final void initializePlatformApi() {
registerNetworkComponents();
registerWirelessTransmitterRangeModifiers();
registerPermissions();
registerSlotReferenceProviders();
}

private void registerAdditionalStorageTypes() {
private void registerStorageTypes() {
PlatformApi.INSTANCE.getStorageTypeRegistry().register(
createIdentifier(ITEM_REGISTRY_KEY),
StorageTypes.ITEM
);
PlatformApi.INSTANCE.getStorageTypeRegistry().register(
createIdentifier(FLUID_REGISTRY_KEY),
StorageTypes.FLUID
);
}

private void registerAdditionalResourceTypes() {
private void registerResourceTypes() {
PlatformApi.INSTANCE.getResourceTypeRegistry().register(
createIdentifier(ITEM_REGISTRY_KEY),
ResourceTypes.ITEM
);
PlatformApi.INSTANCE.getResourceTypeRegistry().register(
createIdentifier(FLUID_REGISTRY_KEY),
ResourceTypes.FLUID
@@ -260,9 +266,6 @@ private void registerWirelessTransmitterRangeModifiers() {

private void registerPermissions() {
for (final BuiltinPermission permission : BuiltinPermission.values()) {
if (permission == BuiltinPermission.SECURITY) {
continue;
}
PlatformApi.INSTANCE.getPermissionRegistry().register(permission.getId(), permission);
}
}
@@ -316,16 +319,7 @@ protected final void registerBlocks(
)));
}

protected final void registerItems(
final RegistryCallback<Item> callback,
final Supplier<AbstractUpgradeItem> regulatorUpgradeItemSupplier,
final Supplier<WirelessGridItem> wirelessGridItemSupplier,
final Supplier<WirelessGridItem> creativeWirelessGridItemSupplier,
final Supplier<PortableGridBlockItem> portableGridBlockItemSupplier,
final Supplier<PortableGridBlockItem> creativePortableGridBlockItemSupplier,
final Supplier<SecurityCardItem> securityCardItemSupplier,
final Supplier<FallbackSecurityCardItem> fallbackSecurityCardItemSupplier
) {
protected final void registerItems(final RegistryCallback<Item> callback) {
registerSimpleItems(callback);
Blocks.INSTANCE.getGrid().registerItems(callback);
Blocks.INSTANCE.getCraftingGrid().registerItems(callback);
@@ -342,23 +336,7 @@ protected final void registerItems(
Blocks.INSTANCE.getNetworkReceiver().registerItems(callback, Items.INSTANCE::addNetworkReceiver);
Blocks.INSTANCE.getNetworkTransmitter().registerItems(callback, Items.INSTANCE::addNetworkTransmitter);
registerStorageItems(callback);
registerUpgrades(callback, regulatorUpgradeItemSupplier);
Items.INSTANCE.setWirelessGrid(callback.register(WIRELESS_GRID, wirelessGridItemSupplier));
Items.INSTANCE.setCreativeWirelessGrid(callback.register(
CREATIVE_WIRELESS_GRID,
creativeWirelessGridItemSupplier
));
callback.register(STORAGE_MONITOR, () -> new SimpleBlockItem(Blocks.INSTANCE.getStorageMonitor()));
Items.INSTANCE.setPortableGrid(callback.register(PORTABLE_GRID, portableGridBlockItemSupplier));
Items.INSTANCE.setCreativePortableGrid(callback.register(
CREATIVE_PORTABLE_GRID,
creativePortableGridBlockItemSupplier
));
Items.INSTANCE.setSecurityCard(callback.register(SECURITY_CARD, securityCardItemSupplier));
Items.INSTANCE.setFallbackSecurityCard(callback.register(
FALLBACK_SECURITY_CARD,
fallbackSecurityCardItemSupplier
));
registerUpgrades(callback);
}

private void registerSimpleItems(final RegistryCallback<Item> callback) {
@@ -373,6 +351,7 @@ private void registerSimpleItems(final RegistryCallback<Item> callback) {
Items.INSTANCE.setWrench(callback.register(WRENCH, WrenchItem::new));
Items.INSTANCE.setStorageHousing(callback.register(STORAGE_HOUSING, SimpleItem::new));
callback.register(MACHINE_CASING, () -> new SimpleBlockItem(Blocks.INSTANCE.getMachineCasing()));
callback.register(STORAGE_MONITOR, () -> new SimpleBlockItem(Blocks.INSTANCE.getStorageMonitor()));
callback.register(INTERFACE, () -> Blocks.INSTANCE.getInterface().createBlockItem());
Items.INSTANCE.setConstructionCore(callback.register(CONSTRUCTION_CORE, SimpleItem::new));
Items.INSTANCE.setDestructionCore(callback.register(DESTRUCTION_CORE, SimpleItem::new));
@@ -435,10 +414,7 @@ private void registerFluidStorageItems(final RegistryCallback<Item> callback,
);
}

private void registerUpgrades(
final RegistryCallback<Item> callback,
final Supplier<AbstractUpgradeItem> regulatorUpgradeItemSupplier
) {
private void registerUpgrades(final RegistryCallback<Item> callback) {
Items.INSTANCE.setUpgrade(callback.register(
ContentIds.UPGRADE,
SimpleItem::new
@@ -485,10 +461,6 @@ private void registerUpgrades(
)
);
Items.INSTANCE.setSilkTouchUpgrade(silkTouchUpgrade);
Items.INSTANCE.setRegulatorUpgrade(callback.register(
ContentIds.REGULATOR_UPGRADE,
regulatorUpgradeItemSupplier
));
Items.INSTANCE.setRangeUpgrade(callback.register(
ContentIds.RANGE_UPGRADE,
() -> new RangeUpgradeItem(PlatformApi.INSTANCE.getUpgradeRegistry(), false)
@@ -774,6 +746,13 @@ protected final void registerRecipeSerializers(final RegistryCallback<RecipeSeri
);
}

protected void registerSlotReferenceProviders() {
PlatformApi.INSTANCE.getSlotReferenceFactoryRegistry().register(
createIdentifier("inventory"),
InventorySlotReferenceFactory.INSTANCE
);
}

protected static boolean allowNbtUpdateAnimation(final ItemStack oldStack, final ItemStack newStack) {
return oldStack.getItem() != newStack.getItem();
}
Loading