Skip to content

Commit

Permalink
Attempt to repair/restore a broken preferences file
Browse files Browse the repository at this point in the history
  • Loading branch information
fdennis committed Dec 9, 2024
1 parent 623ba4a commit 2b78588
Showing 1 changed file with 35 additions and 1 deletion.
36 changes: 35 additions & 1 deletion lib/desktop/init.dart
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:local_notifier/local_notifier.dart';
import 'package:logging/logging.dart';
import 'package:material_symbols_icons/symbols.dart';
import 'package:path/path.dart' as path;
import 'package:path_provider/path_provider.dart';
import 'package:screen_retriever/screen_retriever.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:window_manager/window_manager.dart';
Expand Down Expand Up @@ -125,7 +127,29 @@ Future<Widget> initialize(List<String> argv) async {
_initLogging(args);

await windowManager.ensureInitialized();
final prefs = await SharedPreferences.getInstance();
SharedPreferences prefs;
try {
prefs = await SharedPreferences.getInstance();
} catch (error) {
// Attempt to repair the broken preferences file
Directory? appSupportDirectory = await getApplicationSupportDirectory();
var doesDirectoryExist = await appSupportDirectory.exists();
if (!doesDirectoryExist) {
throw const FormatException('Unable to find correct directory');
}
String appDataPath =
path.join(appSupportDirectory.path, 'shared_preferences.json');
List<int> repairedPreferences = await _repairPreferences(appDataPath);
await File(appDataPath).writeAsBytes(repairedPreferences);

try {
prefs = await SharedPreferences.getInstance();
} catch (error) {
// Unable to repair the preferences file, therefore delete it
await File(appDataPath).delete();
prefs = await SharedPreferences.getInstance();
}
}
final windowManagerHelper = WindowManagerHelper.withPreferences(prefs);
final isHidden = _getIsHidden(args, prefs);

Expand Down Expand Up @@ -413,3 +437,13 @@ class _HelperWaiterState extends ConsumerState<_HelperWaiter> {
}
}
}

Future<List<int>> _repairPreferences(String appDataPath) async {
List<int> contents = await File(appDataPath).readAsBytes();
var contentsGrowable = List<int>.from(contents); // Make the list growable

// Remove any NUL characters
contentsGrowable.removeWhere((item) => item == 0);

return contentsGrowable;
}

0 comments on commit 2b78588

Please sign in to comment.