From 38c3a41279933fbc1bff2a901290e3db18e07a6c Mon Sep 17 00:00:00 2001 From: cpfeiffer Date: Sat, 3 Oct 2015 23:26:36 +0200 Subject: [PATCH] Improve logging setup, should hopefully fix #107 --- .../gadgetbridge/GBApplication.java | 23 +++++++++++-------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/GBApplication.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/GBApplication.java index 72f91be2..4dff5599 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/GBApplication.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/GBApplication.java @@ -36,7 +36,6 @@ public class GBApplication extends Application { public GBApplication() { context = this; - deviceService = createDeviceService(); // don't do anything here, add it to onCreate instead } @@ -59,6 +58,7 @@ public class GBApplication extends Application { // StatusPrinter.print(lc); // Logger logger = LoggerFactory.getLogger(GBApplication.class); + deviceService = createDeviceService(); GB.environment = GBEnvironment.createDeviceEnvironment(); mActivityDatabaseHandler = new ActivityDatabaseHandler(context); loadBlackList(); @@ -79,17 +79,20 @@ public class GBApplication extends Application { System.setProperty("GB_LOGFILES_DIR", dir.getAbsolutePath()); getLogger().info("Gadgetbridge version: " + BuildConfig.VERSION_NAME); } catch (IOException ex) { - Log.e("GBApplication", "External files dir not available, cannot log to file, ex"); - System.setProperty("GB_LOGFILES_DIR", "/dev/null"); + Log.e("GBApplication", "External files dir not available, cannot log to file", ex); + removeFileLogger(); } } else { - try { - ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME); - root.detachAppender("FILE"); - } catch (Throwable ex) { - System.out.println("Error removing logger FILE appender"); - ex.printStackTrace(); - } + removeFileLogger(); + } + } + + private void removeFileLogger() { + try { + ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME); + root.detachAppender("FILE"); + } catch (Throwable ex) { + Log.e("GBApplication", "Error removing logger FILE appender", ex); } }