1 个不稳定版本
0.1.0 | 2020 年 8 月 6 日 |
---|
#846 在 游戏
16KB
206 行
Serbo
Rust 版 Minecraft 服务器管理器
使用方法
要管理一个或多个服务器,您必须首先创建一个管理器。这个结构将允许您控制和管理工作站。
管理器需要三个参数:一个文件夹,用于存放您要管理的服务器文件,一个版本文件夹,其中包含包含与您支持的游戏版本相对应的服务器文件(它们应该这样命名:1.16.1、1.15.2 等),以及一个 jar_name,它是 serbo 应执行的 jar 文件名以启动服务器。
您可以通过调用此管理器的方法来创建、删除、启动、停止、更改服务器版本,以及获取表示在线服务器的结构体的引用,该结构体称为实例。
有了实例,您就可以访问可以访问 stdout(服务器输出)、向服务器发送命令(通过 stdin)或停止该特定服务器的方法。
lib.rs
:
允许简单控制 Minecraft 服务器,以及输入/输出。
示例
use serbo;
use std::error::Error;
use std::io;
fn main() -> Result<(), Box<dyn Error>> {
let mut manager = serbo::Manager::new("servers", "versions","fabric-server-launch.jar");
let port = 25565;
let id = "1";
loop {
let reader = io::stdin();
let mut buf = String::new();
println!("Enter your command.");
reader.read_line(&mut buf)?;
match buf.trim() {
"delete" => {
match manager.delete(id){
Ok(_) => println!("Server deleted."),
Err(e) => println!("{}",e)
}
}
"change_version" => {
let mut send_buf = String::new();
println!("Enter the version to change to.");
reader.read_line(&mut send_buf)?;
//Remove the newline from read_line
send_buf = send_buf[..send_buf.chars().count() - 1].to_string();
manager.change_version(id, &send_buf)?;
}
"create" => match manager.create(id, "1.16.1-fabric") {
Ok(_) => println!("Server Created"),
Err(e) => println!("{}", e),
},
"stop" => {
//Stops the server
println!("Server stopping.");
manager.stop(id)?;
break Ok(());
}
"start" => {
//Starts the server
println!("Server starting.");
match manager.start(id, port) {
Err(e) => println!("{}", e),
Ok(_) => println!("Server started!"),
};
}
"send" => {
//Prompts for a command to send to the server
let instance = manager.get(id);
match instance {
Some(i) => {
let mut send_buf = String::new();
println!("Enter the command to send to the server.");
reader.read_line(&mut send_buf)?;
//Remove the newline from read_line
send_buf = send_buf[..send_buf.chars().count() - 1].to_string();
i.send(send_buf)?;
}
None => println!("Server offline."),
}
}
"get" => {
//Gets the last 5 stdout lines
let instance: &serbo::Instance = manager.get(id).unwrap();
let vec = instance.get(0);
let length = vec.len();
//Create a vec from the last 5 lines
let trimmed_vec;
if length >= 5 {
trimmed_vec = Vec::from(&vec[length - 5..]);
} else {
trimmed_vec = Vec::from(vec);
}
for line in trimmed_vec {
println!("{}", line);
}
}
_ => {
println!("Unrecognized command");
}
}
}
}
依赖关系
~0.1–7MB
~39K SLoC