use core::fmt::{self, Write}; use sc::syscall; const STDIN: i32 = 0; const STDOUT: i32 = 1; pub fn write(msg: &str) { unsafe { syscall!(WRITE, STDOUT, msg.as_ptr(), msg.len()); } } pub fn read(buf_ptr: *const u8, buf_len: usize) { unsafe { syscall!(READ, STDIN, buf_ptr, buf_len); } } pub struct Format<'a> { buf: &'a mut [u8], len: usize, } impl<'a> Format<'a> { pub fn new(buf: &'a mut [u8]) -> Self { Self { buf, len: 0 } } } impl<'a> fmt::Write for Format<'a> { fn write_str(&mut self, s: &str) -> fmt::Result { if self.len > self.buf.len() { write("1"); return Err(fmt::Error); } let remaining_buf = &mut self.buf[self.len..]; let bytes = s.as_bytes(); let write_num = core::cmp::min(bytes.len(), remaining_buf.len()); remaining_buf[..write_num].copy_from_slice(&bytes[..write_num]); self.len += bytes.len(); if write_num < bytes.len() { write("2"); return Err(fmt::Error); } Ok(()) } } pub fn format(buf: &mut [u8], args: fmt::Arguments<'_>) { let mut f = Format::new(buf); f.write_fmt(args).unwrap(); } pub fn format_str<'a>(buf: &'a mut [u8], args: fmt::Arguments<'_>) -> &'a str { let mut f = Format::new(buf); f.write_fmt(args).unwrap(); str::from_utf8(buf).unwrap() } #[macro_export] macro_rules! print { ($len:expr, $($args:tt)*) => { let mut buf = [0u8; $len]; common::write(common::format_str(&mut buf, core::format_args!($($args)*))); }; }