mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-07-28 19:36:13 +00:00

* fix: space's child views didn't update when moving a page into it * chore: remove check logic * feat: integrate fix space into clear cache * fix: translation missing value * chore: update logger version
100 lines
3.0 KiB
Dart
100 lines
3.0 KiB
Dart
import 'dart:async';
|
|
import 'dart:convert';
|
|
import 'dart:ffi';
|
|
import 'dart:io';
|
|
import 'dart:isolate';
|
|
|
|
import 'package:appflowy_backend/rust_stream.dart';
|
|
import 'package:ffi/ffi.dart';
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:logger/logger.dart';
|
|
|
|
import 'ffi.dart' as ffi;
|
|
|
|
export 'package:async/async.dart';
|
|
|
|
enum ExceptionType {
|
|
AppearanceSettingsIsEmpty,
|
|
}
|
|
|
|
class FlowySDKException implements Exception {
|
|
ExceptionType type;
|
|
FlowySDKException(this.type);
|
|
}
|
|
|
|
class FlowySDK {
|
|
static const MethodChannel _channel = MethodChannel('appflowy_backend');
|
|
static Future<String> get platformVersion async {
|
|
final String version = await _channel.invokeMethod('getPlatformVersion');
|
|
return version;
|
|
}
|
|
|
|
FlowySDK();
|
|
|
|
Future<void> dispose() async {}
|
|
|
|
Future<void> init(String configuration) async {
|
|
ffi.set_stream_port(RustStreamReceiver.shared.port);
|
|
ffi.store_dart_post_cobject(NativeApi.postCObject);
|
|
|
|
// On iOS, VSCode can't print logs from Rust, so we need to use a different method to print logs.
|
|
// So we use a shared port to receive logs from Rust and print them using the logger. In release mode, we don't print logs.
|
|
if (Platform.isIOS && kDebugMode) {
|
|
ffi.set_log_stream_port(RustLogStreamReceiver.logShared.port);
|
|
}
|
|
|
|
// final completer = Completer<Uint8List>();
|
|
// // Create a SendPort that accepts only one message.
|
|
// final sendPort = singleCompletePort(completer);
|
|
|
|
final code = ffi.init_sdk(0, configuration.toNativeUtf8());
|
|
if (code != 0) {
|
|
throw Exception('Failed to initialize the SDK');
|
|
}
|
|
// return completer.future;
|
|
}
|
|
}
|
|
|
|
class RustLogStreamReceiver {
|
|
static RustLogStreamReceiver logShared = RustLogStreamReceiver._internal();
|
|
late RawReceivePort _ffiPort;
|
|
late StreamController<Uint8List> _streamController;
|
|
late StreamSubscription<Uint8List> _subscription;
|
|
int get port => _ffiPort.sendPort.nativePort;
|
|
late Logger _logger;
|
|
|
|
RustLogStreamReceiver._internal() {
|
|
_ffiPort = RawReceivePort();
|
|
_streamController = StreamController();
|
|
_ffiPort.handler = _streamController.add;
|
|
_logger = Logger(
|
|
printer: PrettyPrinter(
|
|
methodCount: 0, // number of method calls to be displayed
|
|
errorMethodCount: 8, // number of method calls if stacktrace is provided
|
|
lineLength: 120, // width of the output
|
|
colors: false, // Colorful log messages
|
|
printEmojis: false, // Print an emoji for each log message
|
|
dateTimeFormat:
|
|
DateTimeFormat.none, // Should each log print contain a timestamp
|
|
),
|
|
level: kDebugMode ? Level.trace : Level.info,
|
|
);
|
|
|
|
_subscription = _streamController.stream.listen((data) {
|
|
String decodedString = utf8.decode(data);
|
|
_logger.i(decodedString);
|
|
});
|
|
}
|
|
|
|
factory RustLogStreamReceiver() {
|
|
return logShared;
|
|
}
|
|
|
|
Future<void> dispose() async {
|
|
await _streamController.close();
|
|
await _subscription.cancel();
|
|
_ffiPort.close();
|
|
}
|
|
}
|