#![allow(unused_imports)]
#![allow(unused_variables)]
#![allow(dead_code)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
#![allow(non_upper_case_globals)]
#[cfg(feature = "wasm")]
extern crate wasm_bindgen;
#[cfg(feature = "cli")]
#[macro_use]
pub extern crate prettytable;
#[macro_use]
extern crate serde_json;
#[macro_use]
extern crate lazy_static;
#[macro_use]
extern crate serde_derive;
#[macro_use]
extern crate hiro_system_kit;
#[macro_use]
mod macros;
#[cfg(feature = "wasm")]
use wasm_bindgen::prelude::*;
pub mod analysis;
pub mod codec;
pub mod repl;
pub mod utils;
pub mod clarity {
#![allow(ambiguous_glob_reexports)]
pub use ::clarity::stacks_common::*;
pub use ::clarity::vm::*;
pub use ::clarity::*;
}
struct GlobalContext {
session: Option<Session>,
}
static mut WASM_GLOBAL_CONTEXT: GlobalContext = GlobalContext { session: None };
#[cfg(feature = "cli")]
pub mod frontend;
#[cfg(feature = "cli")]
pub use frontend::Terminal;
use repl::{Session, SessionSettings};
#[cfg(feature = "wasm")]
#[wasm_bindgen]
pub async fn init_session() -> String {
let (session, output) = unsafe {
match WASM_GLOBAL_CONTEXT.session.take() {
Some(session) => (session, "".to_string()),
None => {
let settings = SessionSettings {
include_boot_contracts: vec![
"costs".into(),
"costs-2".into(),
"costs-3".into(),
],
..Default::default()
};
let mut session = Session::new(settings);
let output = session.start_wasm().await;
(session, output)
}
}
};
unsafe {
WASM_GLOBAL_CONTEXT.session = Some(session);
}
output
}
#[cfg(feature = "wasm")]
#[wasm_bindgen]
pub fn handle_command(command: &str) -> String {
let mut session = unsafe {
match WASM_GLOBAL_CONTEXT.session.take() {
Some(session) => session,
None => return "Error: session lost".to_string(),
}
};
let (_, output_lines) = session.handle_command(command);
unsafe {
WASM_GLOBAL_CONTEXT.session = Some(session);
}
output_lines.join("\n").to_string()
}