Jump to content

Decreasing max stack sizes


tuxwonder

Recommended Posts

Hi, I'm new to Minecraft modding (not at all new to programming in general though, no worries), and I'm trying to implement what I thought would be a relatively simple mod to decrease the max stack size of almost all the vanilla items in the game that aren't already at max stack size 1. The goal is to run a multiplayer server with this mod. I've heard read that I'll probably have to re-register all the blocks in the game I want to be modified with new stack size values.

The questions I have are:

1. Is this the easiest strategy for implementing a mod/change like this? Am I correct in understanding it requires re-registering all blocks?

2. If so, what classes in the API should I be looking at for A. grabbing the existing vanilla items in the game, and then B. registering changes made to them? Example code is nice too, but in lieu of that a few pointers to the API will be just fine.

Honestly, I'm mostly just in a bit of disbelief that this seems to be the solution I have to take, why isn't the most popular game on earth more configurable? It seems like you should just be able to modify the value in a datapack, but here we are.

Link to comment
Share on other sites

No dice unfortunately. This is more or less my code:

@Mod("arducraft")
public class ArducraftMod {

  public ArducraftMod() {
    FMLJavaModLoadingContext.get().getModEventBus().addListener(this::onCommonSetup);
  }

  private void onCommonSetup(FMLCommonSetupEvent event) {
    event.enqueueWork(new Runnable() {
      public void run() {
        try {
          Field stackSizeField = Items.COBBLESTONE.getClass().getDeclaredField("maxStackSize");
          stackSizeField.setAccessible(true);
          stackSizeField.set(Items.COBBLESTONE, 4);
          LOGGER.info("Successfully set COBBLESTONE size to 4");
        } catch (NoSuchFieldException ex) {
          LOGGER.error("Failed to set COBBLESTONE size (NoSuchFieldException): " + ex.getMessage());
        } catch (IllegalAccessException ex) {
          LOGGER.error("Failed to set COBBLESTONE size (IllegalAccessException): " + ex.getMessage());
        }
      }
    });
  }
}

With an output of:

[12:28:51] [Render thread/ERROR]: Failed to set COBBLESTONE size (NoSuchFieldException): maxStackSize

Based on the code I found here

Link to comment
Share on other sites

I figured it my above issue, I had to replace the line getting the field to:

Field stackSizeField = Item.class.getDeclaredField("maxStackSize");

Which seems silly because I see no reason they shouldn't do the exact same thing... But this wouldn't be the first time Java has surprised me with how screwy it is!

Thanks for the tip

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Temu, a rapidly emerging e-commerce platform, is making waves in the online shopping world by offering incredible discounts to its customers. Currently, shoppers can claim a $100 discount on their purchases by using specific promo codes. This promotion is particularly appealing for both new and existing customers looking to save on a wide range of products, from fashion and electronics to home goods. How to Claim Your $100 Discount To take advantage of this generous offer, follow these simple steps: 1.      Visit Temu's Website or App: Start by navigating to the Temu platform, either through their website or mobile application. 2.      Create an Account: If you’re a first-time user, you’ll need to sign up for an account. The registration process is quick and straightforward, requiring only basic information. 3.      Browse Products: Explore the extensive catalog of items available on Temu. The platform features a diverse range of products across various categories, ensuring that you can find something that suits your needs. 4.      Add Items to Your Cart: Once you’ve found your desired products, add them to your shopping cart. Be mindful of any minimum purchase requirements that may apply to the coupon code “ACT892435”. 5.      Proceed to Checkout: When you’re ready to finalize your purchase, click on the cart icon and proceed to the checkout page. 6.      Enter the Promo Code: In the designated field for promo codes, input your chosen code (for example, “ACT892435”. After entering the code, click “Apply” to see your discount reflected in the total amount. 7.      Complete Your Purchase: Review your order details and finalize your purchase by providing your payment information. Benefits of Using Temu's Promo Codes “ACT892435” Using a Temu promo code for a $100 discount comes with numerous advantages: ·         Significant Savings: The most obvious benefit is the substantial reduction in your total purchase price, which can make high-ticket items much more affordable. ·         Wide Range of Products: The discount applies across various categories, allowing you to save on everything from clothing and accessories to electronics and home goods. ·         Additional Promotions: Often, these coupon codes “ACT892435” can be combined with other ongoing promotions or sales events on the platform, maximizing your savings even further. ·         User-Friendly Experience: Temu’s website and app are designed for easy navigation, making it simple for users to find products and apply discounts without hassle.
    • Crashlog: https://paste.ee/p/WrGYD I'm thinking the problem might be a client side mod but ive already checked the mod list like 5 times and still cant find the problem
    • I'm unable to join my local forge servers. When running my forge servers of seemingly any version (tested 1.18 to 1.21.1) I get an error message [Forge Version Check/WARN] [ne.mi.fm.VersionChecker/]: Failed to process update information The server continues to start up and run, however I'm unable to join. Looking for solutions? Full error message: (note last "thead warning" error seems to be unrelated and only happened once for 1.20.1) Forge version check warning has happened for every version. [09:52:31] [Forge Version Check/WARN] [ne.mi.fm.VersionChecker/]: Failed to process update information java.net.http.HttpConnectTimeoutException: HTTP connect timed out         at jdk.internal.net.http.HttpClientImpl.send(HttpClientImpl.java:950) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientFacade.send(HttpClientFacade.java:133) ~[java.net.http:?] {}         at net.minecraftforge.fml.VersionChecker$1.openUrlString(VersionChecker.java:142) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {}         at net.minecraftforge.fml.VersionChecker$1.process(VersionChecker.java:180) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {}         at java.lang.Iterable.forEach(Iterable.java:75) ~[?:?] {}         at net.minecraftforge.fml.VersionChecker$1.run(VersionChecker.java:117) ~[fmlcore-1.20.1-47.3.10.jar%23102!/:?] {} Caused by: java.net.http.HttpConnectTimeoutException: HTTP connect timed out         at jdk.internal.net.http.ResponseTimerEvent.handle(ResponseTimerEvent.java:68) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl.purgeTimeoutsAndReturnNextDeadline(HttpClientImpl.java:1788) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl$SelectorManager.run(HttpClientImpl.java:1385) ~[java.net.http:?] {} Caused by: java.net.ConnectException: HTTP connect timed out         at jdk.internal.net.http.ResponseTimerEvent.handle(ResponseTimerEvent.java:69) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl.purgeTimeoutsAndReturnNextDeadline(HttpClientImpl.java:1788) ~[java.net.http:?] {}         at jdk.internal.net.http.HttpClientImpl$SelectorManager.run(HttpClientImpl.java:1385) ~[java.net.http:?] {} [09:52:31] [Yggdrasil Key Fetcher/ERROR] [mojang/YggdrasilServicesKeyInfo]: Failed to request yggdrasil public key com.mojang.authlib.exceptions.AuthenticationUnavailableException: Cannot contact authentication server         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:119) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:91) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilServicesKeyInfo.fetch(YggdrasilServicesKeyInfo.java:94) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilServicesKeyInfo.lambda$get$1(YggdrasilServicesKeyInfo.java:81) ~[authlib-4.0.43.jar%2375!/:?] {}         at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:572) ~[?:?] {}         at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:358) ~[?:?] {}         at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305) ~[?:?] {}         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144) ~[?:?] {}         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642) ~[?:?] {}         at java.lang.Thread.run(Thread.java:1575) ~[?:?] {} Caused by: java.net.SocketTimeoutException: Connect timed out         at sun.nio.ch.NioSocketImpl.timedFinishConnect(NioSocketImpl.java:546) ~[?:?] {}         at sun.nio.ch.NioSocketImpl.connect(NioSocketImpl.java:592) ~[?:?] {}         at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:327) ~[?:?] {}         at java.net.Socket.connect(Socket.java:760) ~[?:?] {}         at sun.security.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:304) ~[?:?] {}         at sun.net.NetworkClient.doConnect(NetworkClient.java:178) ~[?:?] {}         at sun.net.www.http.HttpClient.openServer(HttpClient.java:531) ~[?:?] {}         at sun.net.www.http.HttpClient.openServer(HttpClient.java:636) ~[?:?] {}         at sun.net.www.protocol.https.HttpsClient.<init>(HttpsClient.java:264) ~[?:?] {}         at sun.net.www.protocol.https.HttpsClient.New(HttpsClient.java:377) ~[?:?] {}         at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.getNewHttpClient(AbstractDelegateHttpsURLConnection.java:193) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.plainConnect0(HttpURLConnection.java:1273) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:1114) ~[?:?] {}         at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:179) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1676) ~[?:?] {}         at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1600) ~[?:?] {}         at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:223) ~[?:?] {}         at com.mojang.authlib.HttpAuthenticationService.performGetRequest(HttpAuthenticationService.java:140) ~[authlib-4.0.43.jar%2375!/:?] {}         at com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService.makeRequest(YggdrasilAuthenticationService.java:96) ~[authlib-4.0.43.jar%2375!/:?] {}         ... 9 more [09:52:31] [Server thread/WARN] [minecraft/MinecraftServer]: Can't keep up! Is the server overloaded? Running 5985ms or 119 ticks behind
    • Remove the mod tempad from the mods-folder
    • Hi, deleting the config folder did not appear to work, what mod are you referring to I could try to delete to fix the problem?
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.