Jump to content
View in the app

A better way to browse. Learn more.

Forge Forums

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Featured Replies

Posted

Can someone please send me an example LogHelper for mc1.8?

My Logger won't accept FMLLog.getLogger() as a parent.

 

package net.dimensionshift.mod;

import java.util.logging.Level;
import java.util.logging.Logger;

import net.minecraftforge.fml.common.FMLLog;

public class DimensionShiftLogHelper {
private static Logger logger = Logger.getLogger(DimensionShift.MODID);

public static void init() {
logger.setParent(FMLLog.getLogger());                                               <-- I can't cast FMLLog.getLogger() to Logger
}

public static void log(Level logLevel, String message) {
logger.log(logLevel, message);
}
}

Here could be your advertisement!

FMLLog.getLogger()

returns a

org.apache.logging.log4j.Logger

, and you use a

java.util.logging.Logger

.

Don't PM me with questions. They will be ignored! Make a thread on the appropriate board for support.

 

1.12 -> 1.13 primer by williewillus.

 

1.7.10 and older versions of Minecraft are no longer supported due to it's age! Update to the latest version for support.

 

http://www.howoldisminecraft1710.today/

  • Author

Yeah, I know.  :-\ I already tried all other possible imports, but nothing worked.

My question is how I can create something similar to this in 1.8.

Here could be your advertisement!

  • Author

Ok, thx.

It works now if I use LogManager.getLogger(DimensionShift.MODID).info("TEST  TEST  TEST"); directly, but as soon as I try to move  LogManager.getLogger(DimensionShift.MODID) to a new class it stops working. Any ideas why?

 

public static void log(Level level, String msg){
	LogManager.getLogger(DimensionShift.MODID).log(level, msg);
}

 

	DimensionShiftLogHelper.log(Level.ALL, "Loading DimensionShift Version " + VERSION);

Here could be your advertisement!

It can be useful wrapping the logger in another class, if only to save a few characters when using it:

LogHelper.info("message") vs. MyMainMod.logger.info("Message").

 

Anyway, you can also get your Logger instance specifically for your mod from FMLPreInitializationEvent:

@Mod.EventHandler
public void preInit(FMLPreInitializationEvent event) {
logger = event.getModLog();
}

 

Similar to LogManager.getLogger("YourModId"), but it has the FML log as its parent, keeps formatting consistency in the console for all those log messages, and can be configured from the config/logging.properties file.

  • Author

Yeah, I realized all this when I read the answer above.

I feel really dumb right now.

 

thx anyway.

Here could be your advertisement!

If "MyMod.logger" is too much to type for you... shorten it with a static import (pseudocode):

 

import static MyMod.logger;

...

logger.info("hello world");

That's neat, but the main point of my post was about the benefits of getting the log from FMLPreInitializationEvent instead of using Apache's LogManager directly.

  • Author

I tried both variants, but there was no visible differences.

What exactly is the advantage of getting the log from the PreInit Event?

Here could be your advertisement!

Hm, maybe there isn't a difference any more, but there used to be. Well, just listen to diesieben :P

 

EDIT: Yeah, looks like the documentation is completely wrong, as event.getModLog just returns LogManager.getLogger with your mod id... Before FML switched to the Apache logger, though, I remember it being useful.

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...

Important Information

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

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.