gecko-dev/devtools/server/actors/string.js
Alexandre Poirot 793ced87e6 Bug 1436978 - Stop using Promise.jsm in devtools/server in favor of DOM Promises. r=jdescottes
MozReview-Commit-ID: Hv7uYZKZGIO

--HG--
extra : rebase_source : 95455a3c13b608d96f9a1f3c4a3071c04c7480f8
2018-02-13 02:31:14 -08:00

42 lines
1.1 KiB
JavaScript

/* 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";
var {DebuggerServer} = require("devtools/server/main");
var protocol = require("devtools/shared/protocol");
const {longStringSpec} = require("devtools/shared/specs/string");
exports.LongStringActor = protocol.ActorClassWithSpec(longStringSpec, {
initialize: function (conn, str) {
protocol.Actor.prototype.initialize.call(this, conn);
this.str = str;
this.short = (this.str.length < DebuggerServer.LONG_STRING_LENGTH);
},
destroy: function () {
this.str = null;
protocol.Actor.prototype.destroy.call(this);
},
form: function () {
if (this.short) {
return this.str;
}
return {
type: "longString",
actor: this.actorID,
length: this.str.length,
initial: this.str.substring(0, DebuggerServer.LONG_STRING_INITIAL_LENGTH)
};
},
substring: function (start, end) {
return Promise.resolve(this.str.substring(start, end));
},
release: function () { }
});