Removed extra `\r`s

pull/2/head
Mark 2023-08-04 12:24:39 -07:00
parent 0538b1e547
commit 88e272fd6f
Signed by: Mark
GPG Key ID: AD62BB059C2AAEE4
1 changed files with 102 additions and 77 deletions

View File

@ -26,14 +26,14 @@ fn greeter() -> FormattedText {
return FormattedText::new( return FormattedText::new(
format!( format!(
concat!( concat!(
"[a] ###### [n] @@@@@@\r\n", "[a] ###### [n] @@@@@@\n",
"[a] # ##[n]@@ @\r\n", "[a] # ##[n]@@ @\n",
"[a] ## #[n]@ @@\r\n", "[a] ## #[n]@ @@\n",
"[a] [n]@@@@@@@@@@@@@[a]\r\n", "[a] [n]@@@@@@@@@@@@@[a]\n",
"[n] @@ @[a]# ##\r\n", "[n] @@ @[a]# ##\n",
"[n] @ @@[a]## #\r\n", "[n] @ @@[a]## #\n",
"[n] @@@@@@ [a] ###### [n]\r\n", "[n] @@@@@@ [a] ###### [n]\n",
" [t]Daisy[n] [i]v{ver}[n]\r\n", " [t]Daisy[n] [i]v{ver}[n]\n",
"\n" "\n"
), ),
ver = env!("CARGO_PKG_VERSION") ver = env!("CARGO_PKG_VERSION")
@ -56,24 +56,24 @@ pub fn do_command(
t.push( t.push(
concat!( concat!(
"Daisy is a high-precision, general-purpose\r\n", "Daisy is a high-precision, general-purpose\n",
"scientific calculator.\r\n", "scientific calculator.\n",
"\n", "\n",
" - Use Up/Down arrows to navigate history.\r\n", " - Use Up/Down arrows to navigate history.\n",
" - Use Ctrl-C or Ctrl-D to quit.\r\n", " - Use Ctrl-C or Ctrl-D to quit.\n",
" - Use [c]ans[n] to reference the last result.\r\n", " - Use [c]ans[n] to reference the last result.\n",
" - Use [c]var = 1337[n] to define varibles.\r\n", " - Use [c]var = 1337[n] to define varibles.\n",
"\n", "\n",
"╞═══════════════ [t]Commands[n] ═══════════════╡\r\n", "╞═══════════════ [t]Commands[n] ═══════════════╡\n",
" [c]help[n] Show this help\r\n", " [c]help[n] Show this help\n",
" [c]clear[n] Clear the terminal\r\n", " [c]clear[n] Clear the terminal\n",
" [c]quit[n] Exit daisy\r\n", " [c]quit[n] Exit daisy\n",
//" [c]units[n] List available units\r\n", //" [c]units[n] List available units\n",
" [c]consts[n] List built-in constants\r\n", " [c]consts[n] List built-in constants\n",
" [c]ops[n] List built-in operators\r\n", " [c]ops[n] List built-in operators\n",
" [c]fns[n] List built-in functions\r\n", " [c]fns[n] List built-in functions\n",
" [c]vars[n] List user-defined variables\r\n", " [c]vars[n] List user-defined variables\n",
" [c]del[n] Delete a variable\r\n", " [c]del[n] Delete a variable\n",
"\n\n", "\n\n",
) )
); );
@ -88,22 +88,22 @@ pub fn do_command(
"ops" | "operators" => { "ops" | "operators" => {
return FormattedText::new( return FormattedText::new(
concat!( concat!(
"\r\n", "\n",
"Operators, sorted by priority (high to low).\r\n", "Operators, sorted by priority (high to low).\n",
"High-piority operators are applied first.\r\n\n", "High-piority operators are applied first.\n\n",
"╞═════ [t]Operator[n] ═════╪═════ [t]Syntax[n] ═════╡\r\n", "╞═════ [t]Operator[n] ═════╪═════ [t]Syntax[n] ═════╡\n",
" function [c]sin, cos, etc[n]\r\n", " function [c]sin, cos, etc[n]\n",
" factorial [c]![n]\r\n", " factorial [c]![n]\n",
" powers [c]^, **[n]\r\n", " powers [c]^, **[n]\n",
" implicit multiply [c]3π, 3(2+1), etc[n]\r\n", " implicit multiply [c]3π, 3(2+1), etc[n]\n",
" square root [c]sqrt, rt, √[n]\r\n", " square root [c]sqrt, rt, √[n]\n",
" negate [c]-3, -(1 + 2)[n]\r\n", " negate [c]-3, -(1 + 2)[n]\n",
" modulo (short) [c]%[n]\r\n", " modulo (short) [c]%[n]\n",
" multiply, divide [c]*, /, ×, ÷[n]\r\n", " multiply, divide [c]*, /, ×, ÷[n]\n",
" add, subtract [c]+, -[n]\r\n", " add, subtract [c]+, -[n]\n",
" unit conversion [c]to[n]\r\n", " unit conversion [c]to[n]\n",
" division (long) [c]per[n]\r\n", " division (long) [c]per[n]\n",
" modulo (long) [c]mod[n]\r\n", " modulo (long) [c]mod[n]\n",
"\n\n" "\n\n"
).to_string() ).to_string()
); );
@ -112,25 +112,25 @@ pub fn do_command(
"fns" | "functions" => { "fns" | "functions" => {
return FormattedText::new( return FormattedText::new(
concat!( concat!(
"\r\n╞═══════ [t]Function[n] ═══════╪══════ [t]Syntax[n] ══════╡\r\n", "\n╞═══════ [t]Function[n] ═══════╪══════ [t]Syntax[n] ══════╡\n",
" absolute value [c]abs[n]\r\n", " absolute value [c]abs[n]\n",
" floor, ceiling, round [c]floor, ceil, round[n]\r\n", " floor, ceiling, round [c]floor, ceil, round[n]\n",
" log base e [c]ln[n]\r\n", " log base e [c]ln[n]\n",
" log base 10 [c]log[n]\r\n", " log base 10 [c]log[n]\n",
" sin, arcsin, cosecant [c]sin, asin, csc[n]\r\n", " sin, arcsin, cosecant [c]sin, asin, csc[n]\n",
" cos, arccos, secant [c]cos, acos, secant[n]\r\n", " cos, arccos, secant [c]cos, acos, secant[n]\n",
" tan, arctan, cotan [c]tan, atan, cot[n]\r\n", " tan, arctan, cotan [c]tan, atan, cot[n]\n",
" hyperbolic sin, etc [c]sinh, asinh, csch[n]\r\n", " hyperbolic sin, etc [c]sinh, asinh, csch[n]\n",
" hyperbolic cos, etc [c]cosh, acosh, sech[n]\r\n", " hyperbolic cos, etc [c]cosh, acosh, sech[n]\n",
" hyperbolic tan, etc [c]tanh, atanh, coth[n]\r\n", " hyperbolic tan, etc [c]tanh, atanh, coth[n]\n",
"\n", "\n",
" Celsius to Kelvin [c]fromC, fromCelsius[n]\r\n", " Celsius to Kelvin [c]fromC, fromCelsius[n]\n",
" Kelvin to Celsius [c]toC, toCelsius[n]\r\n", " Kelvin to Celsius [c]toC, toCelsius[n]\n",
" Fahrenheit to Kelvin [c]fromF, fromFahrenheit[n]\r\n", " Fahrenheit to Kelvin [c]fromF, fromFahrenheit[n]\n",
" Kelvin to Fahrenheit [c]toF, toFahrenheit[n]\r\n", " Kelvin to Fahrenheit [c]toF, toFahrenheit[n]\n",
"\n", "\n",
" convert to base unit [c]tobase[n]\r\n", " convert to base unit [c]tobase[n]\n",
" remove units [c]nounit[n]\r\n", " remove units [c]nounit[n]\n",
"\n\n" "\n\n"
).to_string() ).to_string()
); );
@ -138,16 +138,18 @@ pub fn do_command(
"vars" => { "vars" => {
let v = context.get_variables(); let v = context.get_variables();
let f = context.get_functions();
if v.len() == 0 { if v.len() + f.len() == 0 {
return FormattedText::new( return FormattedText::new(
"You have not defined any variables\r\n\n".to_string() "You have not defined any variables\n\n".to_string()
); );
} }
let mut t = FormattedText::new( let mut t = FormattedText::new("".to_string());
"\r\n╞═══ [t]User-Defined Variables[n] ═══╡\r\n".to_string()
); if v.len() != 0 {
t.push("\n╞═══ [t]User-Defined Variables[n] ═══╡\n");
let mut longest = 0; let mut longest = 0;
for (key, _) in v { for (key, _) in v {
@ -160,12 +162,35 @@ pub fn do_command(
let padding = " ".repeat(longest - key.len()); let padding = " ".repeat(longest - key.len());
t.push(&format!( t.push(&format!(
" {key}{padding} = [c]{v}[n]\r\n", " {key}{padding} = [c]{v}[n]\n",
v = value.to_string(), v = value.to_string(),
)); ));
} }
}
t.push("\r\n\n"); if f.len() != 0 {
t.push("\n╞═══ [t]User-Defined Functions[n] ═══╡\n");
let mut longest = 0;
for (key, (args, _exp)) in f {
let s = format!("{key}({})", args.join(", "));
if s.len() > longest {
longest = s.len();
}
}
for (key, (args, exp)) in f {
let padding = " ".repeat(longest - key.len());
t.push(&format!(
" {key}({}){padding} = [c]{v}[n]\n",
args.join(", "),
v = exp.to_string(),
));
}
}
t.push("\n\n");
return t; return t;
}, },
@ -173,7 +198,7 @@ pub fn do_command(
let a = Constant::all_consts(); let a = Constant::all_consts();
let mut t = FormattedText::new( let mut t = FormattedText::new(
"\r\n╞═══ [t]Built-in Constants[n] ═══╡\r\n".to_string() "\n╞═══ [t]Built-in Constants[n] ═══╡\n".to_string()
); );
@ -200,21 +225,21 @@ pub fn do_command(
if args.len() != 2 { if args.len() != 2 {
return FormattedText::new( return FormattedText::new(
format!( format!(
"[c]{first}[n] [t]takes exactly two arguments.[n]\r\n\n", "[c]{first}[n] [t]takes exactly two arguments.[n]\n\n",
) )
); );
} }
let v = args[1].to_string(); let v = args[1].to_string();
let v = substitute(&v); let v = substitute(&v);
let r = context.delete_variable(&v); let r = context.delete(&v);
return match r { return match r {
Ok(()) => { FormattedText::new("".to_string()) }, Ok(()) => { FormattedText::new("".to_string()) },
Err(()) => { Err(()) => {
FormattedText::new( FormattedText::new(
format!( format!(
"[c]{v}[n] [t]isn't a variable.[n]\r\n\n", "[c]{v}[n] [t]isn't a variable.[n]\n\n",
) )
) )
} }