From 0fe24276e3b38b87caa4a0fdf4720069f131ddbc Mon Sep 17 00:00:00 2001 From: kiron1 Date: Sun, 18 Aug 2024 11:49:44 +0800 Subject: [PATCH] paclib: New JS context on new PAC --- paclib/src/engine.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/paclib/src/engine.rs b/paclib/src/engine.rs index 20ebe9a1..6bcfb238 100644 --- a/paclib/src/engine.rs +++ b/paclib/src/engine.rs @@ -15,7 +15,7 @@ pub struct Engine<'a> { } impl<'a> Engine<'a> { - pub fn new() -> Self { + fn mkjs() -> Context<'a> { let mut js = Context::default(); js.register_global_class::().unwrap(); @@ -49,8 +49,11 @@ impl<'a> Engine<'a> { .expect("eval pac_utils.js"); js.eval(Source::from_bytes(crate::DEFAULT_PAC_SCRIPT)) .expect("eval default PAC script"); + js + } - Self { js } + pub fn new() -> Self { + Self { js: Self::mkjs() } } pub fn with_pac_script(pac_script: &str) -> Result { @@ -60,6 +63,7 @@ impl<'a> Engine<'a> { } pub fn set_pac_script(&mut self, pac_script: Option<&str>) -> Result<(), PacScriptError> { + self.js = Self::mkjs(); let pac_script = pac_script.unwrap_or(crate::DEFAULT_PAC_SCRIPT); self.js .eval(Source::from_bytes(pac_script))