chore: README

This commit is contained in:
lollipopkit
2023-12-12 14:18:09 +08:00
parent 47280b1339
commit 2200ff98d7
11 changed files with 48 additions and 46 deletions

View File

@@ -21,11 +21,11 @@ import 'package:xml/xml.dart';
/// ]
///
class NvdiaSmi {
static List<NvdiaSmiItem> fromXml(String raw) {
class NvidiaSmi {
static List<NvidiaSmiItem> fromXml(String raw) {
final xmlData = XmlDocument.parse(raw);
final gpus = xmlData.findAllElements('gpu');
final result = List<NvdiaSmiItem?>.generate(gpus.length, (index) {
final result = List<NvidiaSmiItem?>.generate(gpus.length, (index) {
final gpu = gpus.elementAt(index);
final name = gpu.findElements('product_name').firstOrNull?.innerText;
final temp = gpu
@@ -47,7 +47,7 @@ class NvdiaSmi {
.firstOrNull
?.findElements('process_info');
final memoryProcesses =
List<NvdiaSmiMemProcess?>.generate(processes?.length ?? 0, (index) {
List<NvidiaSmiMemProcess?>.generate(processes?.length ?? 0, (index) {
final process = processes?.elementAt(index);
final pid = process?.findElements('pid').firstOrNull?.innerText;
final name =
@@ -55,7 +55,7 @@ class NvdiaSmi {
final memory =
process?.findElements('used_memory').firstOrNull?.innerText;
if (pid != null && name != null && memory != null) {
return NvdiaSmiMemProcess(
return NvidiaSmiMemProcess(
int.parse(pid),
name,
int.parse(
@@ -78,13 +78,13 @@ class NvdiaSmi {
powerDraw != null &&
powerLimit != null &&
memory != null) {
return NvdiaSmiItem(
return NvidiaSmiItem(
name: name,
uuid: gpu.findElements('uuid').firstOrNull?.innerText ?? '',
temp: int.parse(temp.split(' ').firstOrNull ?? '0'),
percent: int.parse(percent?.split(' ').firstOrNull ?? '0'),
power: '$powerDraw / $powerLimit',
memory: NvdiaSmiMem(
memory: NvidiaSmiMem(
int.parse(memoryTotal?.split(' ').firstOrNull ?? '0'),
int.parse(memoryUsed?.split(' ').firstOrNull ?? '0'),
'MiB',
@@ -100,16 +100,16 @@ class NvdiaSmi {
}
}
class NvdiaSmiItem {
class NvidiaSmiItem {
final String uuid;
final String name;
final int temp;
final String power;
final NvdiaSmiMem memory;
final NvidiaSmiMem memory;
final int percent;
final int fanSpeed;
const NvdiaSmiItem({
const NvidiaSmiItem({
required this.uuid,
required this.name,
required this.temp,
@@ -125,13 +125,13 @@ class NvdiaSmiItem {
}
}
class NvdiaSmiMem {
class NvidiaSmiMem {
final int total;
final int used;
final String unit;
final List<NvdiaSmiMemProcess> processes;
final List<NvidiaSmiMemProcess> processes;
const NvdiaSmiMem(this.total, this.used, this.unit, this.processes);
const NvidiaSmiMem(this.total, this.used, this.unit, this.processes);
@override
String toString() {
@@ -139,12 +139,12 @@ class NvdiaSmiMem {
}
}
class NvdiaSmiMemProcess {
class NvidiaSmiMemProcess {
final int pid;
final String name;
final int memory;
const NvdiaSmiMemProcess(this.pid, this.name, this.memory);
const NvidiaSmiMemProcess(this.pid, this.name, this.memory);
@override
String toString() {

View File

@@ -56,7 +56,7 @@ class ServerStatus {
SystemType system;
String? err;
DiskIO diskIO;
List<NvdiaSmiItem>? nvdia;
List<NvidiaSmiItem>? nvdia;
/// Whether is connectting, parsing and etc.
bool _isBusy = false;

View File

@@ -113,7 +113,7 @@ Future<ServerStatus> _getLinuxStatus(ServerStatusUpdateReq req) async {
}
try {
final nvdia = NvdiaSmi.fromXml(StatusCmdType.nvdia.find(segments));
final nvdia = NvidiaSmi.fromXml(StatusCmdType.nvdia.find(segments));
req.ss.nvdia = nvdia;
} catch (e, s) {
Loggers.parse.warning(e, s);

View File

@@ -2,9 +2,9 @@
class BuildData {
static const String name = "ServerBox";
static const int build = 667;
static const int build = 672;
static const String engine = "3.16.2";
static const String buildAt = "2023-12-09 14:56:57";
static const int modifications = 11;
static const String buildAt = "2023-12-11 11:40:12";
static const int modifications = 3;
static const int script = 31;
}

View File

@@ -318,7 +318,7 @@ class _ServerDetailPageState extends State<ServerDetailPage>
);
}
Widget _buildGpuItem(NvdiaSmiItem item) {
Widget _buildGpuItem(NvidiaSmiItem item) {
final mem = item.memory;
final processes = mem.processes;
final children = <Widget>[];
@@ -378,7 +378,7 @@ class _ServerDetailPageState extends State<ServerDetailPage>
);
}
Widget _buildGpuProcessItem(NvdiaSmiMemProcess process) {
Widget _buildGpuProcessItem(NvidiaSmiMemProcess process) {
return ListTile(
title: Text(
process.name,

View File

@@ -91,7 +91,7 @@ class _ServerPageState extends State<ServerPage>
// Desktop doesn't support pull to refresh
if (isDesktop) return child;
return RefreshIndicator(
key: ServerProvider.refreshKey,
onRefresh: () async => await Pros.server.refreshData(onlyFailed: true),

View File

@@ -41,7 +41,7 @@ class Input extends StatefulWidget {
this.autoFocus = false,
this.onViewPwdTap,
});
@override
State<StatefulWidget> createState() => _InputState();
}
@@ -74,7 +74,9 @@ class _InputState extends State<Input> {
prefix: widget.prefix,
suffixIcon: widget.obscureText
? IconButton(
icon: Icon(_obscureText ? Icons.visibility : Icons.visibility_off),
icon: Icon(
_obscureText ? Icons.visibility : Icons.visibility_off,
),
onPressed: () {
setState(() {
_obscureText = !_obscureText;