4 stable releases
Uses new Rust 2024
| 2.1.0 | Jun 10, 2025 |
|---|---|
| 2.0.0 | Apr 26, 2025 |
| 1.0.1 | Feb 24, 2025 |
| 1.0.0 | Nov 12, 2024 |
#1564 in Filesystem
237 downloads per month
19KB
310 lines
OS System Tools
一个用 Rust 编写的系统工具集合,提供系统信息获取、文件路径管理、串口管理和自动启动配置等功能。
功能特性
-
📊 系统信息监控
- 内存使用情况
- 系统名称和版本
- 主机名
- 网络接口信息
-
📁 路径管理
- 链式API设计
- 目录/文件自动创建
- 类型安全的路径操作
-
🔌 串口管理
- 列出可用串口
- 获取串口详细信息(ID、名称、制造商)
-
🚀 自动启动配置
- 支持 Windows/macOS/Linux
- 配置应用程序自启动
- 支持启用/禁用自启动
系统要求
- Rust 1.70 或更高版本
- 支持的操作系统:
- Windows 10/11
- macOS 10.15+
- Linux (主流发行版)
安装
-
克隆仓库:
git clone https://github.com/Weakcat/ostring_base.git -
构建项目:
cargo build --release
使用示例
系统信息获取
use ostring_base::os_sysinfo::OsSysInfo;
let info = OsSysInfo::get_info();
println!("{:?}", info);
路径管理 (链式API)
use ostring_base::os_path::{PathManager, app_file_path};
// 获取并确保应用配置文件存在
let config_path = app_file_path("myapp", "config.json")?;
// 自定义路径操作
let mut log_manager = PathManager::get_data_dir()?;
log_manager.join_dir("myapp")?
.join_dir("logs")?
.ensure()?;
let log_dir = log_manager.path();
// 文件路径(注意:文件路径后不能再join)
let mut file_manager = PathManager::get_data_dir()?;
file_manager.join_dir("myapp")?
.join_file("data.log")?; // 此时path_type为File
// 以下操作会返回错误
// file_manager.join_dir("logs")?; // 错误:无法在文件路径上进行join操作
// 创建并获取文件路径
file_manager.ensure()?;
let file_path = file_manager.string()?;
串口列表
use ostring_base::os_serialport::serial_port_list;
let ports = serial_port_list();
println!("{:?}", ports);
自动启动配置
use ostring_base::os_autolaunch::AutoLaunchManager;
// 检查是否启用了自动启动
let is_enabled = AutoLaunchManager::is_enabled()?;
println!("自动启动状态: {}", is_enabled);
// 启用自动启动
AutoLaunchManager::update_launch(true)?;
// 禁用自动启动
AutoLaunchManager::update_launch(false)?;
依赖项
serde: 序列化/反序列化支持sysinfo: 系统信息获取serialport: 串口通信auto-launch: 自动启动配置dirs: 系统目录路径获取anyhow: 错误处理
开发
运行测试
cargo test
Dependencies
~3–14MB
~137K SLoC