1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/* 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 http://mozilla.org/MPL/2.0/. */
"use strict";
const {
FrontClassWithSpec,
registerFront,
} = require("resource://devtools/shared/protocol.js");
const {
propertyIteratorSpec,
} = require("resource://devtools/shared/specs/property-iterator.js");
const {
getAdHocFrontOrPrimitiveGrip,
} = require("resource://devtools/client/fronts/object.js");
/**
* A PropertyIteratorFront provides a way to access to property names and
* values of an object efficiently, slice by slice.
* Note that the properties can be sorted in the backend,
* this is controled while creating the PropertyIteratorFront
* from ObjectFront.enumProperties.
*/
class PropertyIteratorFront extends FrontClassWithSpec(propertyIteratorSpec) {
form(data) {
this.actorID = data.actor;
this.count = data.count;
}
async slice(start, count) {
const result = await super.slice({ start, count });
return this._onResult(result);
}
async all() {
const result = await super.all();
return this._onResult(result);
}
_onResult(result) {
if (!result.ownProperties) {
return result;
}
// The result packet can have multiple properties that hold grips which we may need
// to turn into fronts.
const gripKeys = ["value", "getterValue", "get", "set"];
Object.entries(result.ownProperties).forEach(([key, descriptor]) => {
if (descriptor) {
for (const gripKey of gripKeys) {
if (descriptor.hasOwnProperty(gripKey)) {
result.ownProperties[key][gripKey] = getAdHocFrontOrPrimitiveGrip(
descriptor[gripKey],
this
);
}
}
}
});
return result;
}
}
exports.PropertyIteratorFront = PropertyIteratorFront;
registerFront(PropertyIteratorFront);
|