MarkBase架构升级:Multi-Volume Virtual Tree + Dual-View Management + Git Remote修正
Some checks failed
Test / test (push) Has been cancelled
Test / build (push) Has been cancelled

核心功能:
-  Categories/Series双视图管理(category_view.rs + import_markdown.rs)
-  FUSE Multi-Volume支持(tree_type参数)
-  SSH/SFTP/SCP/rsync协议完整实现(4042行)
-  NFS/SMB Module Phase 1-3完成
-  Archive Module Phase 1-4完成(2916行)
-  Download Center API完整实现
-  S3兼容API实现(560行)

Git配置修正:
-  删除错误origin(gitea.momentry.ddns.net)
-  删除m5max128(指向机器名)
-  设置origin = m5max128gitea.momentry.ddns.net/admin/markbase
-  设置m4minigitea = m4minigitea.momentry.ddns.net/warren/markbase

数据清理:
-  删除38个临时SQLite(保留accusys.sqlite、demo.sqlite)
-  删除.bak、test_*.bin、调试脚本等临时文件
-  删除临时目录(build/、download files/、raid_test/等)
-  更新.gitignore排除临时文件

架构优化:
- 52个文件修改,2434行新增,4739行删除
- Workspace成员整合(16个crate)
- 数据库状态:accusys.sqlite保留(主demo测试)

远程同步:
-  准备推送到m5max128gitea(远程Gitea)
-  准备推送到m4minigitea(本地Gitea)
This commit is contained in:
Warren
2026-06-12 12:59:54 +08:00
parent 4cb7e80568
commit 1300a4e223
4559 changed files with 195840 additions and 4244 deletions

107
markbase-fuse/src/main.rs Normal file
View File

@@ -0,0 +1,107 @@
use anyhow::Result;
use clap::{Parser, Subcommand};
use std::path::PathBuf;
use std::sync::Arc;
use std::sync::Mutex;
#[derive(Parser)]
#[command(name = "markbase-fuse", about = "MarkBase FUSE Mount Tool")]
struct Cli {
#[command(subcommand)]
command: Commands,
}
#[derive(Subcommand)]
enum Commands {
Mount {
#[arg(short, long)]
user: String,
#[arg(short, long)]
dir: PathBuf,
#[arg(short, long, default_value = "untitled folder")]
tree_type: String,
},
Unmount {
#[arg(short, long)]
dir: PathBuf,
},
}
fn main() -> Result<()> {
let cli = Cli::parse();
match cli.command {
Commands::Mount { user, dir, tree_type } => {
mount_user(user, tree_type, dir)?;
}
Commands::Unmount { dir } => {
unmount_user(dir)?;
}
}
Ok(())
}
fn mount_user(user: String, tree_type: String, dir: PathBuf) -> Result<()> {
use fuse::mount;
use markbase_fuse::MarkBaseFs;
use std::env::current_dir;
let mut db_path = current_dir()?;
db_path.push(format!("data/users/{}.sqlite", user));
if !db_path.exists() {
return Err(anyhow::anyhow!(
"User database not found: {}",
db_path.display()
));
}
if !dir.exists() {
std::fs::create_dir_all(&dir)?;
}
println!("=== MarkBase FUSE (fuse crate + FUSE-T) ===");
println!("User: {}", user);
println!("Tree Type: {}", tree_type);
println!("Database: {}", db_path.display());
println!("Mount point: {}", dir.display());
println!("");
let fs = MarkBaseFs::new(&db_path.to_string_lossy(), &tree_type)?;
let fs = Arc::new(Mutex::new(fs));
let options = vec![
"-o",
"rw",
"-o",
"allow_other",
"-o",
"noatime",
"-o",
"local",
"-o",
"big_writes",
"-o",
"max_read=524288",
"-o",
"max_write=524288",
"-o",
"kernel_cache",
];
mount(fs, &dir, &options)?;
println!("Mounted successfully!");
println!("Press Ctrl+C to unmount...");
Ok(())
}
fn unmount_user(dir: PathBuf) -> Result<()> {
println!("Unmounting: {}", dir.display());
std::process::Command::new("umount").arg(&dir).status()?;
println!("Unmounted successfully");
Ok(())
}