Flutter's sync log component implementation by DartNative.
iOS & Android
Dart code :
// init log
FFILog.init();
// log message
FFILog.debug("MyApp", "log debug");
FFILog.info("MyApp", "log info");
FFILog.warn("MyApp", "log warn");
FFILog.error("MyApp", "log error", stackTrace: StackTrace.current);
Objective-C code:
// implementation FFILogDelegate
@interface LogImpl() <FFILogDelegate>
@end
@implementation LogImpl
- (int)getLogLevel {
return FFILogLevelAll;
}
- (void)printLog:(int)level tag:(NSString *)tag content:(NSString *)content {
// native logger
NSLog(@"native log|%zd|%@|%@", level, tag, content);
}
@end
// set implementation
[FFILog sharedInstance].delegate = [[LogImpl alloc] init];
Java code:
// set FFILog.ILog implementation
FFILog.setLog(new FFILog.ILog() {
@Override
public void printLog(int level, String tag, String content) {
switch (level) {
case FFILog.ILog.ERROR:
Log.e(tag, content);
break;
case FFILog.ILog.WARN:
Log.w(tag, content);
break;
case FFILog.ILog.INFO:
Log.i(tag, content);
break;
case FFILog.ILog.DEBUG:
Log.d(tag, content);
break;
default:
break;
}
}
@Override
public int getLogLevel() {
return FFILog.ILog.ALL;
}
// If dartnative so path is custom, return so path.
// Otherwise return null.
@Override
public String getCustomDartNativePath() {
return null;
}
});
ffi_log is available under the BSD 3-Clause License. See the LICENSE file for more info.