mirror of
https://github.com/denoland/deno.git
synced 2024-12-22 15:24:46 -05:00
Add SetGlobalTimeout().
To be used for a timers implementation soon.
This commit is contained in:
parent
4fd2b19f64
commit
b088b58f76
6 changed files with 33 additions and 0 deletions
|
@ -15,4 +15,5 @@ export { ErrorKind, DenoError } from "./errors";
|
|||
export { libdeno } from "./libdeno";
|
||||
export { arch, platform } from "./platform";
|
||||
export { trace } from "./trace";
|
||||
export { setGlobalTimeout } from "./timers";
|
||||
export const args: string[] = [];
|
||||
|
|
|
@ -19,6 +19,15 @@ interface Timer {
|
|||
delay: number; // milliseconds
|
||||
}
|
||||
|
||||
export function setGlobalTimeout(timeout: number) {
|
||||
const builder = new flatbuffers.Builder();
|
||||
fbs.SetTimeout.startSetTimeout(builder);
|
||||
fbs.SetTimeout.addTimeout(builder, timeout);
|
||||
const msg = fbs.SetTimeout.endSetTimeout(builder);
|
||||
const res = sendSync(builder, fbs.Any.SetTimeout, msg);
|
||||
assert(res == null);
|
||||
}
|
||||
|
||||
function startTimer(
|
||||
id: number,
|
||||
cb: TimerCallback,
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import { test, assertEqual } from "./test_util.ts";
|
||||
import { setGlobalTimeout } from "deno";
|
||||
|
||||
function deferred() {
|
||||
let resolve;
|
||||
|
@ -95,3 +96,7 @@ test(async function intervalCancelInvalidSilentFail() {
|
|||
// Should silently fail (no panic)
|
||||
clearInterval(2147483647);
|
||||
});
|
||||
|
||||
test(async function SetGlobalTimeoutSmoke() {
|
||||
setGlobalTimeout(50);
|
||||
});
|
||||
|
|
|
@ -45,6 +45,7 @@ pub fn msg_from_js(state: Arc<IsolateState>, bytes: &[u8]) -> (bool, Box<Op>) {
|
|||
msg::Any::Start => handle_start,
|
||||
msg::Any::CodeFetch => handle_code_fetch,
|
||||
msg::Any::CodeCache => handle_code_cache,
|
||||
msg::Any::SetTimeout => handle_set_timeout,
|
||||
msg::Any::Environ => handle_env,
|
||||
msg::Any::FetchReq => handle_fetch_req,
|
||||
msg::Any::TimerStart => handle_timer_start,
|
||||
|
@ -236,6 +237,15 @@ fn handle_code_cache(state: Arc<IsolateState>, base: &msg::Base) -> Box<Op> {
|
|||
}()))
|
||||
}
|
||||
|
||||
fn handle_set_timeout(state: Arc<IsolateState>, base: &msg::Base) -> Box<Op> {
|
||||
let msg = base.msg_as_set_timeout().unwrap();
|
||||
let val = msg.timeout() as isize;
|
||||
state
|
||||
.timeout
|
||||
.swap(val, std::sync::atomic::Ordering::Relaxed);
|
||||
ok_future(empty_buf())
|
||||
}
|
||||
|
||||
fn handle_set_env(state: Arc<IsolateState>, base: &msg::Base) -> Box<Op> {
|
||||
let msg = base.msg_as_set_env().unwrap();
|
||||
let key = msg.key().unwrap();
|
||||
|
|
|
@ -16,6 +16,7 @@ use std;
|
|||
use std::collections::HashMap;
|
||||
use std::ffi::CStr;
|
||||
use std::ffi::CString;
|
||||
use std::sync::atomic::AtomicIsize;
|
||||
use std::sync::mpsc;
|
||||
use std::sync::Arc;
|
||||
use std::sync::Mutex;
|
||||
|
@ -48,6 +49,7 @@ pub struct Isolate {
|
|||
// Isolate cannot be passed between threads but IsolateState can. So any state that
|
||||
// needs to be accessed outside the main V8 thread should be inside IsolateState.
|
||||
pub struct IsolateState {
|
||||
pub timeout: AtomicIsize,
|
||||
pub dir: deno_dir::DenoDir,
|
||||
pub timers: Mutex<HashMap<u32, futures::sync::oneshot::Sender<()>>>,
|
||||
pub argv: Vec<String>,
|
||||
|
@ -85,6 +87,7 @@ impl Isolate {
|
|||
rx,
|
||||
ntasks: 0,
|
||||
state: Arc::new(IsolateState {
|
||||
timeout: AtomicIsize::new(-1),
|
||||
dir: deno_dir::DenoDir::new(flags.reload, None).unwrap(),
|
||||
timers: Mutex::new(HashMap::new()),
|
||||
argv: argv_rest,
|
||||
|
|
|
@ -4,6 +4,7 @@ union Any {
|
|||
CodeFetch,
|
||||
CodeFetchRes,
|
||||
CodeCache,
|
||||
SetTimeout,
|
||||
Exit,
|
||||
TimerStart,
|
||||
TimerReady,
|
||||
|
@ -115,6 +116,10 @@ table CodeCache {
|
|||
output_code: string;
|
||||
}
|
||||
|
||||
table SetTimeout {
|
||||
timeout: int;
|
||||
}
|
||||
|
||||
table Exit {
|
||||
code: int;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue