如何设置Apache Commons Logger

时间:2016-09-21 18:50:15

标签: j2objc

任何人都知道如何设置Apache Commons Logger?看起来像是people got it running,但我却失败了。

我目前的设置非常简单:

的build.gradle:

compile('commons-logging:commons-logging:1.2')
j2objcTranslation 'commons-logging:commons-logging:1.2'

记录器初始化:

private static Log logger = LogFactory.getLog(ApiService.class);

还有一个非常简单的logging.properties文件,如果需要可以附加。

在iOS模拟器上进行翻译和运行后,会抛出以下异常:

2016-09-21 19:39:35.960 temple8-ios[32544:598370] Fucking logger
2016-09-21 19:39:36.048 temple8-ios[32544:598370] *** Terminating app due to uncaught exception     'OrgApacheCommonsLoggingLogConfigurationException', reason:  'java.lang.ClassNotFoundException:  org.apache.commons.logging.impl.LogFactoryImpl (Caused by  java.lang.ClassNotFoundException:  org.apache.commons.logging.impl.LogFactoryImpl)'
 *** First throw call stack:
(
    0   CoreFoundation                      0x000000010e471d85     __exceptionPreprocess + 165
    1   libobjc.A.dylib                     0x000000010d40cdeb objc_exception_throw + 48
    2   temple8-ios                         0x000000010c056a27 OrgApacheCommonsLoggingLogFactory_newFactoryWithNSString_withJavaLangClassLoader_withJavaLangClassLoader_ + 327
    3   temple8-ios                         0x000000010c059d06 OrgApacheCommonsLoggingLogFactory_getFactory + 3030
    4   temple8-ios                         0x000000010c056026 OrgApacheCommonsLoggingLogFactory_getLogWithIOSClass_ + 70

编辑1

@tball在his answer中提供了一些很棒的细节,但这导致了一个新问题。我已在项目中添加了LogFactoryImpl的静态引用,并包含java.util.logging.IOSLogHandler。尝试翻译该类时,编译器会抛出以下错误:

/java/util/logging/IOSLogHandler.m:58:17: error: method definition for 'IOS_LOG_MANAGER_DEFAULTS' not found [-Werror,-Wincomplete-implementation]
 @implementation JavaUtilLoggingIOSLogHandler
                ^
java/util/logging/IOSLogHandler.h:34:1: note: method    'IOS_LOG_MANAGER_DEFAULTS' declared here
+ (NSString *)IOS_LOG_MANAGER_DEFAULTS;
^
1 error generated.

我正在使用j2objC github repositoryIOSLogHandler的最新版本,并已将生成的IOSLogHandler.m发布在gist上。

非常感谢所有的帮助!

1 个答案:

答案 0 :(得分:1)

链接器不包括org.apache.commons.logging.impl.LogFactoryImpl,因为它是动态加载的,因此在链接期间没有需要解析的引用。我不知道如何在Gradle中解决这个问题,但有两种常规解决方案:

  1. 与-ObjC标志链接,这会导致所有静态库中的所有Objective C类链接到应用程序。但是,这可能会引入许多不需要的类,因此请检查二进制文件大小之前和之后的应用程序,看看它是否可以接受。

  2. 在已链接到您的应用的类中,添加对org.apache.commons.logging.impl.LogFactoryImpl的引用。它可以很简单:

    @SuppressWarnings("未使用&#34) private static final类loggingImplClass =     LogFactoryImpl.class;