mirror of
https://github.com/lollipopkit/flutter_server_box.git
synced 2025-12-17 23:34:24 +01:00
#30 fix: parse mem
This commit is contained in:
@@ -102,13 +102,11 @@ final cpuTempReg = RegExp(r'(x86_pkg_temp|cpu_thermal)');
|
||||
String parseCPUTemp(String type, String value) {
|
||||
const noMatch = "/sys/class/thermal/thermal_zone*/type";
|
||||
// Not support to get CPU temperature
|
||||
if (value.contains(noMatch) ||
|
||||
type.contains(noMatch) ||
|
||||
value.isEmpty ||
|
||||
type.isEmpty) {
|
||||
if (type.contains(noMatch) || value.isEmpty || type.isEmpty) {
|
||||
return '';
|
||||
}
|
||||
final split = type.split('\n');
|
||||
// if no match, use idx 0
|
||||
int idx = 0;
|
||||
for (var item in split) {
|
||||
if (item.contains(cpuTempReg)) {
|
||||
|
||||
@@ -1,16 +1,24 @@
|
||||
class Memory {
|
||||
int total;
|
||||
int used;
|
||||
int free;
|
||||
int cache;
|
||||
int avail;
|
||||
|
||||
Memory({
|
||||
required this.total,
|
||||
required this.used,
|
||||
required this.free,
|
||||
required this.cache,
|
||||
required this.avail,
|
||||
});
|
||||
|
||||
double get availPercent {
|
||||
if (avail == 0) {
|
||||
return free / total;
|
||||
}
|
||||
return avail / total;
|
||||
}
|
||||
|
||||
double get usedPercent => 1 - availPercent;
|
||||
}
|
||||
|
||||
final memItemReg = RegExp(r'([A-Z].+:)\s+([0-9]+) kB');
|
||||
@@ -18,22 +26,49 @@ final memItemReg = RegExp(r'([A-Z].+:)\s+([0-9]+) kB');
|
||||
Memory parseMem(String raw) {
|
||||
final items = raw.split('\n').map((e) => memItemReg.firstMatch(e)).toList();
|
||||
|
||||
final total = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'MemTotal:')?.group(2) ?? '1',
|
||||
);
|
||||
final free = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'MemFree:')?.group(2) ?? '0',
|
||||
);
|
||||
final cached = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'Cached:')?.group(2) ?? '0',
|
||||
);
|
||||
final available = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'MemAvailable:')?.group(2) ?? '0',
|
||||
);
|
||||
final total = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'MemTotal:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'1',
|
||||
) ??
|
||||
1;
|
||||
final free = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'MemFree:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'0',
|
||||
) ??
|
||||
0;
|
||||
final cached = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'Cached:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'0',
|
||||
) ??
|
||||
0;
|
||||
final available = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'MemAvailable:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'0',
|
||||
) ??
|
||||
0;
|
||||
|
||||
return Memory(
|
||||
total: total,
|
||||
used: total - available,
|
||||
free: free,
|
||||
cache: cached,
|
||||
avail: available,
|
||||
@@ -42,39 +77,61 @@ Memory parseMem(String raw) {
|
||||
|
||||
class Swap {
|
||||
final int total;
|
||||
final int used;
|
||||
final int free;
|
||||
final int cached;
|
||||
|
||||
Swap({
|
||||
required this.total,
|
||||
required this.used,
|
||||
required this.free,
|
||||
required this.cached,
|
||||
});
|
||||
|
||||
double get usedPercent => 1 - free / total;
|
||||
|
||||
double get freePercent => free / total;
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'Swap{total: $total, used: $used, free: $free, cached: $cached}';
|
||||
return 'Swap{total: $total, free: $free, cached: $cached}';
|
||||
}
|
||||
}
|
||||
|
||||
Swap parseSwap(String raw) {
|
||||
final items = raw.split('\n').map((e) => memItemReg.firstMatch(e)).toList();
|
||||
|
||||
final total = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'SwapTotal:')?.group(2) ?? '1',
|
||||
);
|
||||
final free = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'SwapFree:')?.group(2) ?? '0',
|
||||
);
|
||||
final cached = int.parse(
|
||||
items.firstWhere((e) => e?.group(1) == 'SwapCached:')?.group(2) ?? '0',
|
||||
);
|
||||
final total = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'SwapTotal:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'1',
|
||||
) ??
|
||||
1;
|
||||
final free = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'SwapFree:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'1',
|
||||
) ??
|
||||
1;
|
||||
final cached = int.tryParse(
|
||||
items
|
||||
.firstWhere(
|
||||
(e) => e?.group(1) == 'SwapCached:',
|
||||
orElse: () => null,
|
||||
)
|
||||
?.group(2) ??
|
||||
'0',
|
||||
) ??
|
||||
0;
|
||||
|
||||
return Swap(
|
||||
total: total,
|
||||
used: total - free,
|
||||
free: free,
|
||||
cached: cached,
|
||||
);
|
||||
|
||||
@@ -59,9 +59,11 @@ class PkgProvider extends BusyProvider {
|
||||
|
||||
Future<void> refresh() async {
|
||||
final result = await _update();
|
||||
_parse(result);
|
||||
try {} catch (e) {
|
||||
try {
|
||||
_parse(result);
|
||||
} catch (e) {
|
||||
error = '[Server Raw]:\n$result\n[App Error]:\n$e';
|
||||
rethrow;
|
||||
} finally {
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
@@ -4,6 +4,6 @@ class BuildData {
|
||||
static const String name = "ServerBox";
|
||||
static const int build = 293;
|
||||
static const String engine = "3.7.11";
|
||||
static const String buildAt = "2023-05-09 19:48:09.523377";
|
||||
static const int modifications = 4;
|
||||
static const String buildAt = "2023-05-10 12:26:52.686";
|
||||
static const int modifications = 11;
|
||||
}
|
||||
|
||||
@@ -7,7 +7,6 @@ import '../model/server/conn_status.dart';
|
||||
|
||||
Memory get _initMemory => Memory(
|
||||
total: 1,
|
||||
used: 0,
|
||||
free: 1,
|
||||
cache: 0,
|
||||
avail: 1,
|
||||
@@ -39,7 +38,6 @@ NetSpeed get initNetSpeed => NetSpeed(
|
||||
);
|
||||
Swap get _initSwap => Swap(
|
||||
total: 1,
|
||||
used: 0,
|
||||
free: 1,
|
||||
cached: 0,
|
||||
);
|
||||
|
||||
@@ -1,9 +1,10 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:toolbox/core/persistant_store.dart';
|
||||
import 'package:toolbox/core/utils/platform.dart';
|
||||
|
||||
class SettingStore extends PersistentStore {
|
||||
StoreProperty<int> get primaryColor =>
|
||||
property('primaryColor', defaultValue: Colors.deepPurpleAccent.value);
|
||||
property('primaryColor', defaultValue: Colors.pink.value);
|
||||
|
||||
StoreProperty<int> get serverStatusUpdateInterval =>
|
||||
property('serverStatusUpdateInterval', defaultValue: 3);
|
||||
@@ -37,5 +38,5 @@ class SettingStore extends PersistentStore {
|
||||
StoreProperty<String> get fontPath => property('fontPath');
|
||||
|
||||
/// Backgroud running (Android)
|
||||
StoreProperty<bool> get bgRun => property('bgRun', defaultValue: true);
|
||||
StoreProperty<bool> get bgRun => property('bgRun', defaultValue: isAndroid);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user