aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/testbindingmaplike.rs
diff options
context:
space:
mode:
authorSamson <16504129+sagudev@users.noreply.github.com>2023-09-06 15:08:45 +0200
committerGitHub <noreply@github.com>2023-09-06 13:08:45 +0000
commite0a6281e7375468f367aadf398d5a836512d9df6 (patch)
treed29cc82409d68f4b053de615d66c17ac779addd5 /components/script/dom/testbindingmaplike.rs
parent3df284cf54d9d99daf32794a030efa6358f5cf39 (diff)
downloadservo-e0a6281e7375468f367aadf398d5a836512d9df6.tar.gz
servo-e0a6281e7375468f367aadf398d5a836512d9df6.zip
Impl Setlike and Maplike (#30237)
* MallocSizeOf for Index{Set, Map} * like as iterable in WebIDL * Codegen magic for like interfaces * TestBinding for like * Test for Setlike and Maplike test bindings * Some fixes * Switch to any.js * nit * Keep order
Diffstat (limited to 'components/script/dom/testbindingmaplike.rs')
-rw-r--r--components/script/dom/testbindingmaplike.rs90
1 files changed, 90 insertions, 0 deletions
diff --git a/components/script/dom/testbindingmaplike.rs b/components/script/dom/testbindingmaplike.rs
new file mode 100644
index 00000000000..83ebcce4646
--- /dev/null
+++ b/components/script/dom/testbindingmaplike.rs
@@ -0,0 +1,90 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
+
+// check-tidy: no specs after this line
+
+use crate::dom::bindings::cell::DomRefCell;
+use crate::dom::bindings::codegen::Bindings::TestBindingMaplikeBinding::TestBindingMaplikeMethods;
+use crate::dom::bindings::error::Fallible;
+use crate::dom::bindings::like::Maplike;
+use crate::dom::bindings::reflector::{reflect_dom_object_with_proto, Reflector};
+use crate::dom::bindings::root::DomRoot;
+use crate::dom::bindings::str::DOMString;
+use crate::dom::globalscope::GlobalScope;
+use crate::maplike;
+use dom_struct::dom_struct;
+use indexmap::IndexMap;
+use js::rust::HandleObject;
+
+use super::bindings::error::Error;
+
+/// maplike<DOMString, long>
+#[dom_struct]
+pub struct TestBindingMaplike {
+ reflector: Reflector,
+ #[custom_trace]
+ internal: DomRefCell<IndexMap<DOMString, i32>>,
+}
+
+impl TestBindingMaplike {
+ fn new(global: &GlobalScope, proto: Option<HandleObject>) -> DomRoot<TestBindingMaplike> {
+ reflect_dom_object_with_proto(
+ Box::new(TestBindingMaplike {
+ reflector: Reflector::new(),
+ internal: DomRefCell::new(IndexMap::new()),
+ }),
+ global,
+ proto,
+ )
+ }
+
+ #[allow(non_snake_case)]
+ pub fn Constructor(
+ global: &GlobalScope,
+ proto: Option<HandleObject>,
+ ) -> Fallible<DomRoot<TestBindingMaplike>> {
+ Ok(TestBindingMaplike::new(global, proto))
+ }
+}
+
+impl TestBindingMaplikeMethods for TestBindingMaplike {
+ fn SetInternal(&self, key: DOMString, value: i32) {
+ self.internal.set(key, value)
+ }
+
+ fn ClearInternal(&self) {
+ self.internal.clear()
+ }
+
+ fn DeleteInternal(&self, key: DOMString) -> bool {
+ self.internal.delete(key)
+ }
+
+ fn HasInternal(&self, key: DOMString) -> bool {
+ self.internal.has(key)
+ }
+
+ fn GetInternal(&self, key: DOMString) -> Fallible<i32> {
+ // TODO: error type?
+ self.internal
+ .borrow()
+ .get(&key)
+ .ok_or_else(|| Error::Type(format!("No entry for key {key}")))
+ .copied()
+ }
+
+ fn Size(&self) -> u32 {
+ self.internal.size()
+ }
+}
+
+// this error is wrong because if we inline Self::Key and Self::Value all errors are gone
+// TODO: FIX THIS
+#[allow(unrooted_must_root)]
+impl Maplike for TestBindingMaplike {
+ type Key = DOMString;
+ type Value = i32;
+
+ maplike!(self, internal);
+}