Added wasm implementations for formattedtext

pull/6/head
Mark 2023-09-20 14:23:46 -07:00
parent c237e9d5ec
commit 470c3a49ed
Signed by: Mark
GPG Key ID: AD62BB059C2AAEE4
4 changed files with 72 additions and 52 deletions

View File

@ -0,0 +1,33 @@
use std::ops::Add;
#[derive(Debug)]
#[derive(Clone)]
pub struct FormattedText {
pub(super) text: String
}
impl ToString for FormattedText {
fn to_string(&self) -> String { return self.text.clone(); }
}
impl FormattedText {
pub fn new(s: String) -> FormattedText {
return FormattedText {
text: s
}
}
pub fn push(&mut self, s: &str) {
self.text.push_str(s);
}
}
impl Add for FormattedText {
type Output = Self;
fn add(self, other: Self) -> Self::Output {
return FormattedText::new(format!("{}{}", self.text, other.text));
}
}

12
src/formattedtext/mod.rs Normal file
View File

@ -0,0 +1,12 @@
mod formattedtext;
pub use formattedtext::FormattedText;
// Select write implementation by target system
cfg_if::cfg_if! {
if #[cfg(target_family = "unix")] {
mod unix_backend;
} else if #[cfg(target_arch = "wasm32")] {
mod wasm_backend;
}
}

View File

@ -1,34 +1,12 @@
use super::FormattedText;
use std::io::Write; use std::io::Write;
use crate::context::Context;
use termion::raw::RawTerminal; use termion::raw::RawTerminal;
use termion::color; use termion::color;
use termion::style; use termion::style;
use termion::clear; use termion::clear;
use termion::cursor; use termion::cursor;
use std::ops::Add;
use crate::context::Context;
#[derive(Debug)]
#[derive(Clone)]
pub struct FormattedText {
text: String
}
impl ToString for FormattedText {
fn to_string(&self) -> String { return self.text.clone(); }
}
fn format_map_none(c: char) -> Option<String> {
Some(match c {
'n'|'i'|'t'|'a'|
'e'|'c'|'s'|'r'|
'p'
=> { "".to_string() },
_ => { return None }
})
}
fn format_map_ansi(c: char) -> Option<String> { fn format_map_ansi(c: char) -> Option<String> {
Some(match c { Some(match c {
@ -65,6 +43,17 @@ fn format_map_ansi(c: char) -> Option<String> {
} }
fn format_map_none(c: char) -> Option<String> {
Some(match c {
'n'|'i'|'t'|'a'|
'e'|'c'|'s'|'r'|
'p'
=> { "".to_string() },
_ => { return None }
})
}
// style::reset also resets color. // style::reset also resets color.
// Make sure color comes AFTER style reset. // Make sure color comes AFTER style reset.
fn format_map_full(c: char) -> Option<String> { fn format_map_full(c: char) -> Option<String> {
@ -102,9 +91,6 @@ fn format_map_full(c: char) -> Option<String> {
}) })
} }
impl FormattedText { impl FormattedText {
pub fn newline(stdout: &mut RawTerminal<std::io::Stdout>) -> Result<(), std::io::Error> { pub fn newline(stdout: &mut RawTerminal<std::io::Stdout>) -> Result<(), std::io::Error> {
write!(stdout, "\n")?; write!(stdout, "\n")?;
@ -119,20 +105,6 @@ impl FormattedText {
_ => unreachable!("Invalid term_color_type") _ => unreachable!("Invalid term_color_type")
} }
} }
}
impl FormattedText {
pub fn new(s: String) -> FormattedText {
return FormattedText {
text: s
}
}
pub fn push(&mut self, s: &str) {
self.text.push_str(s);
}
pub fn write(&self, context: &Context, stdout: &mut RawTerminal<std::io::Stdout>) -> Result<(), std::io::Error> { pub fn write(&self, context: &Context, stdout: &mut RawTerminal<std::io::Stdout>) -> Result<(), std::io::Error> {
@ -155,7 +127,7 @@ impl FormattedText {
'[' => { '[' => {
let a = chars.next().unwrap(); let a = chars.next().unwrap();
// Handle double [[ as escaped [ // Treat double [[ as escaped [
if a == '[' { s.push('['); } if a == '[' { s.push('['); }
let b = chars.next().unwrap(); let b = chars.next().unwrap();
@ -189,13 +161,4 @@ impl FormattedText {
write!(stdout, "\r{}", s)?; write!(stdout, "\r{}", s)?;
return Ok(()); return Ok(());
} }
}
impl Add for FormattedText {
type Output = Self;
fn add(self, other: Self) -> Self::Output {
return FormattedText::new(format!("{}{}", self.text, other.text));
}
} }

View File

@ -0,0 +1,12 @@
use super::FormattedText;
impl FormattedText {
pub fn newline() -> Result<(), ()> {
print!("\n");
return Ok(());
}
pub fn write(&self) -> String {
return self.text.clone();
}
}