2023-01-02 16:00:42 -05:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
2021-08-31 13:08:16 +02:00
|
|
|
//! This example shows you how to define ops in Rust and then call them from
|
|
|
|
//! JavaScript.
|
|
|
|
|
|
|
|
use deno_core::Extension;
|
|
|
|
use deno_core::JsRuntime;
|
|
|
|
use deno_core::RuntimeOptions;
|
|
|
|
|
|
|
|
fn main() {
|
2023-01-08 23:48:46 +01:00
|
|
|
let my_ext = Extension::builder("my_ext")
|
2022-03-15 23:43:17 +01:00
|
|
|
.middleware(|op| match op.name {
|
2022-03-22 16:39:58 +01:00
|
|
|
"op_print" => op.disable(),
|
2022-03-15 23:43:17 +01:00
|
|
|
_ => op,
|
2021-08-31 13:08:16 +02:00
|
|
|
})
|
|
|
|
.build();
|
|
|
|
|
|
|
|
// Initialize a runtime instance
|
|
|
|
let mut runtime = JsRuntime::new(RuntimeOptions {
|
|
|
|
extensions: vec![my_ext],
|
|
|
|
..Default::default()
|
|
|
|
});
|
|
|
|
|
|
|
|
// Deno.core.print() will now be a NOP
|
|
|
|
runtime
|
2023-04-04 06:46:31 -06:00
|
|
|
.execute_script_static("<usage>", r#"Deno.core.print("I'm broken")"#)
|
2021-08-31 13:08:16 +02:00
|
|
|
.unwrap();
|
|
|
|
}
|