From 746e44754bdc25bac257a8fbe170e0f66fa1b725 Mon Sep 17 00:00:00 2001 From: Andrew Morris Date: Fri, 3 Nov 2023 08:51:14 +1100 Subject: [PATCH] More inline formats --- vstc/src/db_command.rs | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/vstc/src/db_command.rs b/vstc/src/db_command.rs index bb7e321..755da9b 100644 --- a/vstc/src/db_command.rs +++ b/vstc/src/db_command.rs @@ -45,7 +45,8 @@ pub fn db_command(args: &[String]) { Some("-i") => println!("TODO: use database {} interactively", path), arg => 'b: { if let Some(arg) = arg { - if arg.starts_with("this.") { + // TODO: Document variations here + if arg.starts_with("this.") || arg.starts_with('{') || arg.starts_with('(') { break 'b db_run_inline(&path, arg); } } @@ -184,10 +185,17 @@ fn db_run_inline(path: &str, source: &str) { .unwrap() .unwrap(); - let compile_result = compile_str(&format!( - "export default function() {{ return (\n {}\n); }}", - source - )); + let full_source = { + if source.starts_with("this.") || source.starts_with('(') { + format!("export default function() {{ return (\n {}\n); }}", source) + } else if source.starts_with('{') { + format!("export default function() {}", source) + } else { + panic!("Unrecognized inline code: {}", source); + } + }; + + let compile_result = compile_str(&full_source); for (path, diagnostics) in compile_result.diagnostics.iter() { // TODO: Fix exit call