From 63f623647bb2ae4a24d5b502dea5c48801ff2ff9 Mon Sep 17 00:00:00 2001 From: Filip Tibell Date: Thu, 8 Jun 2023 12:30:16 +0200 Subject: [PATCH] Make sure print and warn globals also flush stdout --- packages/lib/src/builtins/top_level.rs | 30 +++++++++++++++----------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/packages/lib/src/builtins/top_level.rs b/packages/lib/src/builtins/top_level.rs index 2d22027..1b0e092 100644 --- a/packages/lib/src/builtins/top_level.rs +++ b/packages/lib/src/builtins/top_level.rs @@ -1,4 +1,5 @@ use mlua::prelude::*; +use std::io::{self, Write as _}; #[cfg(feature = "roblox")] use lune_roblox::datatypes::extension::RobloxUserdataTypenameExt; @@ -8,28 +9,31 @@ use crate::lua::{ task::TaskReference, }; -// HACK: We need to preserve the default behavior of the -// print and error functions, for pcall and such, which -// is really tricky to do from scratch so we will just -// proxy the default print and error functions here - -pub fn print(lua: &Lua, args: LuaMultiValue) -> LuaResult<()> { - let formatted = pretty_format_multi_value(&args)?; - let print: LuaFunction = lua.named_registry_value("print")?; - print.call(formatted)?; +pub fn print(_: &Lua, args: LuaMultiValue) -> LuaResult<()> { + let formatted = format!("{}\n", pretty_format_multi_value(&args)?); + let mut stdout = io::stdout(); + stdout.write_all(formatted.as_bytes())?; + stdout.flush()?; Ok(()) } -pub fn warn(lua: &Lua, args: LuaMultiValue) -> LuaResult<()> { - let print: LuaFunction = lua.named_registry_value("print")?; - print.call(format!( +pub fn warn(_: &Lua, args: LuaMultiValue) -> LuaResult<()> { + let formatted = format!( "{}\n{}", format_label("warn"), pretty_format_multi_value(&args)? - ))?; + ); + let mut stdout = io::stdout(); + stdout.write_all(formatted.as_bytes())?; + stdout.flush()?; Ok(()) } +// HACK: We need to preserve the default behavior of +// the lua error function, for pcall and such, which +// is really tricky to do from scratch so we will +// just proxy the default function here instead + pub fn error(lua: &Lua, (arg, level): (LuaValue, Option)) -> LuaResult<()> { let error: LuaFunction = lua.named_registry_value("error")?; let trace: LuaFunction = lua.named_registry_value("dbg.trace")?;