aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/bindings/conversions.rs
diff options
context:
space:
mode:
authorGeorge Roman <george.roman.99@gmail.com>2019-06-30 19:21:28 +0300
committerGeorge Roman <george.roman.99@gmail.com>2019-07-02 00:47:41 +0300
commitb26aa3ec19b1270fa1b3583974320f415acb0bbf (patch)
tree708c7e0e79390430daa8d680acec3f4f5f9f9184 /components/script/dom/bindings/conversions.rs
parent3e446ef7181ea742b1a3de0162217d98e7b8cbc5 (diff)
downloadservo-b26aa3ec19b1270fa1b3583974320f415acb0bbf.tar.gz
servo-b26aa3ec19b1270fa1b3583974320f415acb0bbf.zip
Add support for more array-like types in is_array_like
Diffstat (limited to 'components/script/dom/bindings/conversions.rs')
-rw-r--r--components/script/dom/bindings/conversions.rs42
1 files changed, 36 insertions, 6 deletions
diff --git a/components/script/dom/bindings/conversions.rs b/components/script/dom/bindings/conversions.rs
index 161354479b6..68b397e5402 100644
--- a/components/script/dom/bindings/conversions.rs
+++ b/components/script/dom/bindings/conversions.rs
@@ -40,6 +40,11 @@ use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::{ByteString, DOMString, USVString};
use crate::dom::bindings::trace::{JSTraceable, RootedTraceableBox};
use crate::dom::bindings::utils::DOMClass;
+use crate::dom::filelist::FileList;
+use crate::dom::htmlcollection::HTMLCollection;
+use crate::dom::htmlformcontrolscollection::HTMLFormControlsCollection;
+use crate::dom::htmloptionscollection::HTMLOptionsCollection;
+use crate::dom::nodelist::NodeList;
use js::conversions::latin1_to_string;
pub use js::conversions::ConversionBehavior;
pub use js::conversions::{ConversionResult, FromJSValConvertible, ToJSValConvertible};
@@ -548,13 +553,38 @@ impl<T: DomObject> ToJSValConvertible for DomRoot<T> {
}
}
-/// Returns whether `value` is an array-like object.
-/// Note: Currently only Arrays are supported.
-/// TODO: Expand this to support sequences and other array-like objects
+/// Returns whether `value` is an array-like object (Array, FileList,
+/// HTMLCollection, HTMLFormControlsCollection, HTMLOptionsCollection,
+/// NodeList).
pub unsafe fn is_array_like(cx: *mut JSContext, value: HandleValue) -> bool {
- let mut result = false;
- assert!(JS_IsArrayObject(cx, value, &mut result));
- result
+ let mut is_array = false;
+ assert!(JS_IsArrayObject(cx, value, &mut is_array));
+ if is_array {
+ return true;
+ }
+
+ let object: *mut JSObject = match FromJSValConvertible::from_jsval(cx, value, ()).unwrap() {
+ ConversionResult::Success(object) => object,
+ _ => return false,
+ };
+
+ if root_from_object::<FileList>(object, cx).is_ok() {
+ return true;
+ }
+ if root_from_object::<HTMLCollection>(object, cx).is_ok() {
+ return true;
+ }
+ if root_from_object::<HTMLFormControlsCollection>(object, cx).is_ok() {
+ return true;
+ }
+ if root_from_object::<HTMLOptionsCollection>(object, cx).is_ok() {
+ return true;
+ }
+ if root_from_object::<NodeList>(object, cx).is_ok() {
+ return true;
+ }
+
+ false
}
/// Get a property from a JS object.