1
Fork 0
mirror of https://github.com/redstrate/Kawari.git synced 2025-07-20 19:57:47 +00:00
kawari/src/world/event.rs
Joshua Goins d292e1d676 Fix signedness of scene yield params
According to the decompiled Lua code, they sometimes can return
negative numbers (like -1, to indicate an error.) I also improved
the debug display of these in the server log a bit.
2025-06-25 23:28:12 -04:00

105 lines
3.1 KiB
Rust

use mlua::{Function, Lua};
use crate::{common::ObjectTypeId, config::get_config};
use super::{LuaPlayer, Zone};
pub struct Event {
pub file_name: String,
lua: Lua,
pub id: u32,
}
impl Event {
pub fn new(id: u32, path: &str) -> Self {
let lua = Lua::new();
let config = get_config();
let file_name = format!("{}/{}", &config.world.scripts_location, path);
let result = std::fs::read(&file_name);
if let Err(err) = std::fs::read(&file_name) {
tracing::warn!("Failed to load {}: {:?}", file_name, err);
return Self { file_name, lua, id };
}
let file = result.unwrap();
if let Err(err) = lua.load(file).set_name("@".to_string() + &file_name).exec() {
tracing::warn!("Syntax error in {}: {:?}", file_name, err);
return Self { file_name, lua, id };
}
lua.globals().set("EVENT_ID", id).unwrap();
Self { file_name, lua, id }
}
pub fn enter_territory(&mut self, player: &mut LuaPlayer, zone: &Zone) {
let mut run_script = || {
self.lua.scope(|scope| {
let player = scope.create_userdata_ref_mut(player)?;
let zone = scope.create_userdata_ref(zone)?;
let func: Function = self.lua.globals().get("onEnterTerritory")?;
func.call::<()>((player, zone))?;
Ok(())
})
};
if let Err(err) = run_script() {
tracing::warn!("Syntax error in {}: {:?}", self.file_name, err);
}
}
pub fn scene_finished(&mut self, player: &mut LuaPlayer, scene: u16) {
let mut run_script = || {
self.lua.scope(|scope| {
let player = scope.create_userdata_ref_mut(player)?;
let func: Function = self.lua.globals().get("onSceneFinished")?;
func.call::<()>((player, scene))?;
Ok(())
})
};
if let Err(err) = run_script() {
tracing::warn!("Syntax error in {}: {:?}", self.file_name, err);
}
}
pub fn talk(&mut self, target_id: ObjectTypeId, player: &mut LuaPlayer) {
let mut run_script = || {
self.lua.scope(|scope| {
let player = scope.create_userdata_ref_mut(player)?;
let func: Function = self.lua.globals().get("onTalk")?;
func.call::<()>((target_id, player))?;
Ok(())
})
};
if let Err(err) = run_script() {
tracing::warn!("Syntax error in {}: {:?}", self.file_name, err);
}
}
pub fn finish(&mut self, scene: u16, results: &[i32], player: &mut LuaPlayer) {
let mut run_script = || {
self.lua.scope(|scope| {
let player = scope.create_userdata_ref_mut(player)?;
let func: Function = self.lua.globals().get("onReturn")?;
func.call::<()>((scene, results, player))?;
Ok(())
})
};
if let Err(err) = run_script() {
tracing::warn!("Syntax error in {}: {:?}", self.file_name, err);
}
}
}