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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
/* 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 { sourceSpec } = require("resource://devtools/shared/specs/source.js");
const {
FrontClassWithSpec,
registerFront,
} = require("resource://devtools/shared/protocol.js");
const {
ArrayBufferFront,
} = require("resource://devtools/client/fronts/array-buffer.js");
/**
* A SourceFront provides a way to access the source text of a script.
*
* @param client DevToolsClient
* The DevTools Client instance.
* @param form Object
* The form sent across the remote debugging protocol.
*/
class SourceFront extends FrontClassWithSpec(sourceSpec) {
constructor(client, form) {
super(client);
if (form) {
this._url = form.url;
// this is here for the time being, until the source front is managed
// via protocol.js marshalling
this.actorID = form.actor;
}
}
form(json) {
this._url = json.url;
}
get actor() {
return this.actorID;
}
get url() {
return this._url;
}
// Alias for source.blackbox to avoid changing protocol.js packets
blackBox(range) {
return this.blackbox(range);
}
// Alias for source.unblackbox to avoid changing protocol.js packets
unblackBox() {
return this.unblackbox();
}
/**
* Get a Front for either an ArrayBuffer or LongString
* for this SourceFront's source.
*/
async source() {
const response = await super.source();
return this._onSourceResponse(response);
}
_onSourceResponse(response) {
const { contentType, source } = response;
if (source instanceof ArrayBufferFront) {
return source.slice(0, source.length).then(function(resp) {
if (resp.error) {
return resp;
}
// Keeping str as a string, ArrayBuffer/Uint8Array will not survive
// setIn/mergeIn operations.
const str = atob(resp.encoded);
const newResponse = {
source: {
binary: str,
toString: () => "[wasm]",
},
contentType,
};
return newResponse;
});
}
return source.substring(0, source.length).then(function(resp) {
if (resp.error) {
return resp;
}
const newResponse = {
source: resp,
contentType,
};
return newResponse;
});
}
}
exports.SourceFront = SourceFront;
registerFront(SourceFront);
|