2021-09-10 13:46:15 +02:00
|
|
|
import 'dart:convert';
|
|
|
|
|
2021-09-04 14:35:04 +02:00
|
|
|
import 'package:flutter/foundation.dart';
|
2021-09-10 13:46:15 +02:00
|
|
|
import 'package:nc_photos/mobile/platform.dart'
|
|
|
|
if (dart.library.html) 'package:nc_photos/web/platform.dart' as platform;
|
|
|
|
|
|
|
|
class LogCapturer {
|
|
|
|
factory LogCapturer() {
|
|
|
|
if (_inst == null) {
|
|
|
|
_inst = LogCapturer._();
|
|
|
|
}
|
|
|
|
return _inst!;
|
|
|
|
}
|
|
|
|
|
|
|
|
LogCapturer._();
|
|
|
|
|
|
|
|
/// Start capturing logs
|
|
|
|
void start() {
|
|
|
|
_isEnable = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Stop capturing and save the captured logs
|
|
|
|
Future<dynamic> stop() {
|
|
|
|
_isEnable = false;
|
|
|
|
final saver = platform.FileSaver();
|
|
|
|
final content = Utf8Encoder().convert(_logs.join("\n"));
|
|
|
|
_logs.clear();
|
|
|
|
return saver.saveFile("nc-photos.log", content);
|
|
|
|
}
|
|
|
|
|
|
|
|
void onLog(String log) {
|
|
|
|
if (_isEnable) {
|
|
|
|
_logs.add(log);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool get isEnable => _isEnable;
|
|
|
|
|
|
|
|
final _logs = <String>[];
|
|
|
|
bool _isEnable = false;
|
|
|
|
|
|
|
|
static LogCapturer? _inst;
|
|
|
|
}
|
2021-09-04 14:35:04 +02:00
|
|
|
|
|
|
|
const bool shouldLogFileName = kDebugMode;
|