@theia/memory-inspector 1.45.0 → 1.46.0-next.72
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +71 -71
- package/lib/browser/diff-widget/memory-diff-options-widget.d.ts +36 -36
- package/lib/browser/diff-widget/memory-diff-options-widget.js +132 -132
- package/lib/browser/diff-widget/memory-diff-select-widget.d.ts +50 -50
- package/lib/browser/diff-widget/memory-diff-select-widget.js +137 -137
- package/lib/browser/diff-widget/memory-diff-table-widget.d.ts +77 -77
- package/lib/browser/diff-widget/memory-diff-table-widget.js +314 -314
- package/lib/browser/diff-widget/memory-diff-widget-types.d.ts +41 -41
- package/lib/browser/diff-widget/memory-diff-widget-types.js +23 -23
- package/lib/browser/editable-widget/memory-editable-table-widget.d.ts +64 -64
- package/lib/browser/editable-widget/memory-editable-table-widget.js +324 -324
- package/lib/browser/memory-inspector-frontend-contribution.d.ts +46 -46
- package/lib/browser/memory-inspector-frontend-contribution.js +291 -291
- package/lib/browser/memory-inspector-frontend-module.d.ts +21 -21
- package/lib/browser/memory-inspector-frontend-module.js +87 -87
- package/lib/browser/memory-provider/cdt-gdb-memory-provider.d.ts +35 -35
- package/lib/browser/memory-provider/cdt-gdb-memory-provider.js +136 -136
- package/lib/browser/memory-provider/memory-provider-service.d.ts +36 -36
- package/lib/browser/memory-provider/memory-provider-service.js +101 -101
- package/lib/browser/memory-provider/memory-provider.d.ts +65 -65
- package/lib/browser/memory-provider/memory-provider.js +96 -96
- package/lib/browser/memory-provider/memory-provider.spec.d.ts +16 -16
- package/lib/browser/memory-provider/memory-provider.spec.js +23 -23
- package/lib/browser/memory-widget/memory-options-widget.d.ts +136 -136
- package/lib/browser/memory-widget/memory-options-widget.js +564 -564
- package/lib/browser/memory-widget/memory-table-widget.d.ts +146 -146
- package/lib/browser/memory-widget/memory-table-widget.js +487 -487
- package/lib/browser/memory-widget/memory-widget.d.ts +33 -33
- package/lib/browser/memory-widget/memory-widget.js +112 -112
- package/lib/browser/register-widget/register-filter-service.d.ts +42 -42
- package/lib/browser/register-widget/register-filter-service.js +81 -81
- package/lib/browser/register-widget/register-options-widget.d.ts +81 -81
- package/lib/browser/register-widget/register-options-widget.js +338 -338
- package/lib/browser/register-widget/register-table-widget.d.ts +77 -77
- package/lib/browser/register-widget/register-table-widget.js +230 -230
- package/lib/browser/register-widget/register-widget-types.d.ts +29 -29
- package/lib/browser/register-widget/register-widget-types.js +35 -35
- package/lib/browser/utils/memory-commands.d.ts +27 -27
- package/lib/browser/utils/memory-commands.js +67 -67
- package/lib/browser/utils/memory-hover-renderer.d.ts +33 -33
- package/lib/browser/utils/memory-hover-renderer.js +111 -111
- package/lib/browser/utils/memory-recents.d.ts +27 -27
- package/lib/browser/utils/memory-recents.js +52 -52
- package/lib/browser/utils/memory-widget-components.d.ts +58 -58
- package/lib/browser/utils/memory-widget-components.js +69 -69
- package/lib/browser/utils/memory-widget-manager.d.ts +50 -50
- package/lib/browser/utils/memory-widget-manager.js +182 -182
- package/lib/browser/utils/memory-widget-utils.d.ts +113 -113
- package/lib/browser/utils/memory-widget-utils.js +42 -42
- package/lib/browser/utils/memory-widget-variable-utils.d.ts +57 -57
- package/lib/browser/utils/memory-widget-variable-utils.js +143 -143
- package/lib/browser/utils/multi-select-bar.d.ts +31 -31
- package/lib/browser/utils/multi-select-bar.js +34 -34
- package/lib/browser/wrapper-widgets/memory-dock-panel.d.ts +24 -24
- package/lib/browser/wrapper-widgets/memory-dock-panel.js +48 -48
- package/lib/browser/wrapper-widgets/memory-dockpanel-placeholder-widget.d.ts +23 -23
- package/lib/browser/wrapper-widgets/memory-dockpanel-placeholder-widget.js +57 -57
- package/lib/browser/wrapper-widgets/memory-layout-widget.d.ts +51 -51
- package/lib/browser/wrapper-widgets/memory-layout-widget.js +191 -191
- package/lib/common/util.d.ts +21 -21
- package/lib/common/util.js +30 -30
- package/lib/common/utils.spec.d.ts +16 -16
- package/lib/common/utils.spec.js +45 -45
- package/package.json +4 -4
- package/src/browser/diff-widget/memory-diff-options-widget.tsx +152 -152
- package/src/browser/diff-widget/memory-diff-select-widget.tsx +163 -163
- package/src/browser/diff-widget/memory-diff-table-widget.tsx +366 -366
- package/src/browser/diff-widget/memory-diff-widget-types.ts +45 -45
- package/src/browser/editable-widget/memory-editable-table-widget.tsx +359 -359
- package/src/browser/memory-inspector-frontend-contribution.ts +301 -301
- package/src/browser/memory-inspector-frontend-module.ts +118 -118
- package/src/browser/memory-provider/cdt-gdb-memory-provider.ts +132 -132
- package/src/browser/memory-provider/memory-provider-service.ts +86 -86
- package/src/browser/memory-provider/memory-provider.spec.ts +23 -23
- package/src/browser/memory-provider/memory-provider.ts +119 -119
- package/src/browser/memory-widget/memory-options-widget.tsx +738 -738
- package/src/browser/memory-widget/memory-table-widget.tsx +625 -625
- package/src/browser/memory-widget/memory-widget.ts +114 -114
- package/src/browser/register-widget/register-filter-service.ts +76 -76
- package/src/browser/register-widget/register-options-widget.tsx +393 -393
- package/src/browser/register-widget/register-table-widget.tsx +276 -276
- package/src/browser/register-widget/register-widget-types.ts +45 -45
- package/src/browser/register-widget/register-widget.css +34 -34
- package/src/browser/style/index.css +746 -746
- package/src/browser/style/memory-lock.svg +21 -21
- package/src/browser/style/memory-view.svg +20 -20
- package/src/browser/style/register-lock.svg +29 -29
- package/src/browser/style/register-view.svg +28 -28
- package/src/browser/utils/memory-commands.ts +76 -76
- package/src/browser/utils/memory-hover-renderer.ts +113 -113
- package/src/browser/utils/memory-recents.ts +58 -58
- package/src/browser/utils/memory-widget-components.tsx +193 -193
- package/src/browser/utils/memory-widget-manager.ts +179 -179
- package/src/browser/utils/memory-widget-utils.tsx +132 -132
- package/src/browser/utils/memory-widget-variable-utils.ts +170 -170
- package/src/browser/utils/multi-select-bar.css +61 -61
- package/src/browser/utils/multi-select-bar.tsx +75 -75
- package/src/browser/wrapper-widgets/memory-dock-panel.ts +51 -51
- package/src/browser/wrapper-widgets/memory-dockpanel-placeholder-widget.tsx +38 -38
- package/src/browser/wrapper-widgets/memory-layout-widget.tsx +167 -167
- package/src/common/util.ts +28 -28
- package/src/common/utils.spec.ts +52 -52
|
@@ -1,325 +1,325 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/********************************************************************************
|
|
3
|
-
* Copyright (C) 2021 Ericsson and others.
|
|
4
|
-
*
|
|
5
|
-
* This program and the accompanying materials are made available under the
|
|
6
|
-
* terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
-
* http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
-
*
|
|
9
|
-
* This Source Code may also be made available under the following Secondary
|
|
10
|
-
* Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
-
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
-
* with the GNU Classpath Exception which is available at
|
|
13
|
-
* https://www.gnu.org/software/classpath/license.html.
|
|
14
|
-
*
|
|
15
|
-
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
-
********************************************************************************/
|
|
17
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
21
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
-
};
|
|
23
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
-
exports.MemoryEditableTableWidget = exports.EditableMemoryWidget = void 0;
|
|
25
|
-
const browser_1 = require("@theia/core/lib/browser");
|
|
26
|
-
const promise_util_1 = require("@theia/core/lib/common/promise-util");
|
|
27
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
28
|
-
const React = require("@theia/core/shared/react");
|
|
29
|
-
const Long = require("long");
|
|
30
|
-
const util_1 = require("../../common/util");
|
|
31
|
-
const memory_table_widget_1 = require("../memory-widget/memory-table-widget");
|
|
32
|
-
const memory_widget_utils_1 = require("../utils/memory-widget-utils");
|
|
33
|
-
const nls_1 = require("@theia/core/lib/common/nls");
|
|
34
|
-
var EditableMemoryWidget;
|
|
35
|
-
(function (EditableMemoryWidget) {
|
|
36
|
-
EditableMemoryWidget.ID = 'editable.memory.widget';
|
|
37
|
-
})(EditableMemoryWidget = exports.EditableMemoryWidget || (exports.EditableMemoryWidget = {}));
|
|
38
|
-
let MemoryEditableTableWidget = class MemoryEditableTableWidget extends memory_table_widget_1.MemoryTableWidget {
|
|
39
|
-
constructor() {
|
|
40
|
-
super(...arguments);
|
|
41
|
-
this.pendingMemoryEdits = new Map();
|
|
42
|
-
this.memoryEditsCompleted = new promise_util_1.Deferred();
|
|
43
|
-
this.highlightedField = Long.fromInt(-1);
|
|
44
|
-
this.doShowMoreMemoryBefore = false;
|
|
45
|
-
this.doShowMoreMemoryAfter = false;
|
|
46
|
-
this.handleClearEditClick = () => this.clearEdits();
|
|
47
|
-
this.submitMemoryEdits = async () => {
|
|
48
|
-
this.memoryEditsCompleted = new promise_util_1.Deferred();
|
|
49
|
-
let didUpdateMemory = false;
|
|
50
|
-
for (const [key, edit] of this.createUniqueEdits()) {
|
|
51
|
-
try {
|
|
52
|
-
await this.doWriteMemory(edit);
|
|
53
|
-
didUpdateMemory = true;
|
|
54
|
-
this.pendingMemoryEdits.delete(key);
|
|
55
|
-
}
|
|
56
|
-
catch (e) {
|
|
57
|
-
console.warn('Problem writing memory with arguments', edit, '\n', e);
|
|
58
|
-
const text = e instanceof Error ? e.message : 'Unknown error';
|
|
59
|
-
this.showWriteError(key, text);
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
this.memoryEditsCompleted.resolve();
|
|
64
|
-
if (didUpdateMemory) {
|
|
65
|
-
this.optionsWidget.fetchNewMemory();
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
this.handleTableClick = (event) => {
|
|
69
|
-
var _a, _b;
|
|
70
|
-
const target = event.target;
|
|
71
|
-
if ((_a = target.classList) === null || _a === void 0 ? void 0 : _a.contains('eight-bits')) {
|
|
72
|
-
this.highlightedField = (0, util_1.hexStrToUnsignedLong)((_b = target.getAttribute('data-id')) !== null && _b !== void 0 ? _b : '-0x1');
|
|
73
|
-
this.update();
|
|
74
|
-
event.stopPropagation();
|
|
75
|
-
}
|
|
76
|
-
};
|
|
77
|
-
this.handleTableInput = (event) => {
|
|
78
|
-
var _a, _b;
|
|
79
|
-
if (this.highlightedField.lessThan(0)) {
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
const keyCode = (_a = browser_1.KeyCode.createKeyCode(event.nativeEvent).key) === null || _a === void 0 ? void 0 : _a.keyCode;
|
|
83
|
-
const initialHighlight = this.highlightedField;
|
|
84
|
-
const initialHighlightIndex = initialHighlight.subtract(this.memory.address);
|
|
85
|
-
if (keyCode === browser_1.Key.TAB.keyCode) {
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
const arrayElementsPerRow = (this.options.byteSize / 8) * this.options.bytesPerGroup * this.options.groupsPerRow;
|
|
89
|
-
const isAlreadyEdited = this.pendingMemoryEdits.has(this.highlightedField.toString());
|
|
90
|
-
const oldValue = (_b = this.pendingMemoryEdits.get(initialHighlight.toString())) !== null && _b !== void 0 ? _b : this.memory.bytes[initialHighlightIndex.toInt()].toString(16).padStart(2, '0');
|
|
91
|
-
let possibleNewHighlight = new Long(-1);
|
|
92
|
-
let newValue = oldValue;
|
|
93
|
-
switch (keyCode) {
|
|
94
|
-
case browser_1.Key.ARROW_DOWN.keyCode:
|
|
95
|
-
possibleNewHighlight = initialHighlight.add(arrayElementsPerRow);
|
|
96
|
-
event.preventDefault();
|
|
97
|
-
event.stopPropagation();
|
|
98
|
-
break;
|
|
99
|
-
case browser_1.Key.ARROW_UP.keyCode:
|
|
100
|
-
possibleNewHighlight = initialHighlight.greaterThan(arrayElementsPerRow) ? initialHighlight.subtract(arrayElementsPerRow) : possibleNewHighlight;
|
|
101
|
-
event.preventDefault();
|
|
102
|
-
event.stopPropagation();
|
|
103
|
-
break;
|
|
104
|
-
case browser_1.Key.ARROW_RIGHT.keyCode:
|
|
105
|
-
possibleNewHighlight = initialHighlight.add(1);
|
|
106
|
-
event.preventDefault();
|
|
107
|
-
event.stopPropagation();
|
|
108
|
-
break;
|
|
109
|
-
case browser_1.Key.ARROW_LEFT.keyCode:
|
|
110
|
-
possibleNewHighlight = initialHighlight.greaterThan(0) ? initialHighlight.subtract(1) : possibleNewHighlight;
|
|
111
|
-
break;
|
|
112
|
-
case browser_1.Key.BACKSPACE.keyCode:
|
|
113
|
-
newValue = oldValue.slice(0, oldValue.length - 1);
|
|
114
|
-
break;
|
|
115
|
-
case browser_1.Key.DELETE.keyCode:
|
|
116
|
-
newValue = '';
|
|
117
|
-
break;
|
|
118
|
-
case browser_1.Key.ENTER.keyCode:
|
|
119
|
-
this.submitMemoryEdits();
|
|
120
|
-
break;
|
|
121
|
-
case browser_1.Key.ESCAPE.keyCode:
|
|
122
|
-
if (isAlreadyEdited) {
|
|
123
|
-
this.clearEdits(this.highlightedField);
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
this.clearEdits();
|
|
127
|
-
}
|
|
128
|
-
break;
|
|
129
|
-
default: {
|
|
130
|
-
const keyValue = parseInt(browser_1.KeyCode.createKeyCode(event.nativeEvent).toString(), 16);
|
|
131
|
-
if (!Number.isNaN(keyValue)) {
|
|
132
|
-
newValue = isAlreadyEdited ? oldValue : '';
|
|
133
|
-
if (newValue.length < 2) {
|
|
134
|
-
newValue += keyValue.toString(16);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
if (this.isInBounds(possibleNewHighlight)) {
|
|
140
|
-
this.highlightedField = possibleNewHighlight;
|
|
141
|
-
}
|
|
142
|
-
const valueWasChanged = newValue !== oldValue;
|
|
143
|
-
if (valueWasChanged) {
|
|
144
|
-
this.pendingMemoryEdits.set(this.highlightedField.toString(), newValue);
|
|
145
|
-
}
|
|
146
|
-
if (valueWasChanged || !this.highlightedField.equals(initialHighlight)) {
|
|
147
|
-
this.update();
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
async doInit() {
|
|
152
|
-
this.memoryEditsCompleted.resolve();
|
|
153
|
-
await super.doInit();
|
|
154
|
-
this.addClass('editable');
|
|
155
|
-
}
|
|
156
|
-
resetModifiedValue(valueAddress) {
|
|
157
|
-
const didChange = this.pendingMemoryEdits.delete(valueAddress.toString());
|
|
158
|
-
if (didChange) {
|
|
159
|
-
this.update();
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
getState() {
|
|
163
|
-
super.getState();
|
|
164
|
-
if (!this.isInBounds(this.highlightedField)) {
|
|
165
|
-
this.highlightedField = this.memory.address;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
async handleMemoryChange(newMemory) {
|
|
169
|
-
await this.memoryEditsCompleted.promise;
|
|
170
|
-
if (newMemory.bytes.length === 0) {
|
|
171
|
-
this.pendingMemoryEdits.clear();
|
|
172
|
-
}
|
|
173
|
-
super.handleMemoryChange(newMemory);
|
|
174
|
-
}
|
|
175
|
-
areSameRegion(a, b) {
|
|
176
|
-
return b !== undefined && a.address.equals(b.address) && a.bytes.length === b.bytes.length;
|
|
177
|
-
}
|
|
178
|
-
getTableFooter() {
|
|
179
|
-
var _a, _b;
|
|
180
|
-
const showButtons = !!this.pendingMemoryEdits.size && !this.writeErrorInfo;
|
|
181
|
-
return ((showButtons || this.writeErrorInfo) && (React.createElement("div", { className: 'memory-edit-button-container' },
|
|
182
|
-
showButtons && React.createElement("button", { className: 'theia-button secondary', onClick: this.handleClearEditClick, type: 'reset', title: nls_1.nls.localize('theia/memory-inspector/editable/clear', 'Clear Changes') }, nls_1.nls.localize('theia/memory-inspector/editable/clear', 'Clear Changes')),
|
|
183
|
-
showButtons && React.createElement("button", { className: 'theia-button main', onClick: this.submitMemoryEdits, type: 'submit', title: nls_1.nls.localize('theia/memory-inspector/editable/apply', 'Apply Changes') }, nls_1.nls.localize('theia/memory-inspector/editable/apply', 'Apply Changes')),
|
|
184
|
-
!!this.writeErrorInfo && React.createElement("div", { className: 'memory-edit-error' },
|
|
185
|
-
React.createElement("div", { className: 'memory-edit-error-location' }, `Error writing to 0x${Long.fromString((_a = this.writeErrorInfo) === null || _a === void 0 ? void 0 : _a.location).toString(16)}`),
|
|
186
|
-
React.createElement("div", { className: 'memory-edit-error-details' }, (_b = this.writeErrorInfo) === null || _b === void 0 ? void 0 : _b.error)))));
|
|
187
|
-
}
|
|
188
|
-
getBitAttributes(arrayOffset, iteratee) {
|
|
189
|
-
var _a, _b, _c;
|
|
190
|
-
const attributes = super.getBitAttributes(arrayOffset, iteratee);
|
|
191
|
-
const classNames = (_b = (_a = attributes.className) === null || _a === void 0 ? void 0 : _a.split(' ')) !== null && _b !== void 0 ? _b : [];
|
|
192
|
-
const itemID = this.memory.address.add(arrayOffset);
|
|
193
|
-
const isHighlight = itemID.equals(this.highlightedField);
|
|
194
|
-
const isEditPending = this.pendingMemoryEdits.has(itemID.toString());
|
|
195
|
-
const padder = isHighlight && isEditPending ? '\xa0' : '0'; // non-breaking space so it doesn't look like plain whitespace.
|
|
196
|
-
const stringValue = ((_c = this.pendingMemoryEdits.get(itemID.toString())) !== null && _c !== void 0 ? _c : this.memory.bytes[arrayOffset].toString(16)).padStart(2, padder);
|
|
197
|
-
if (!this.options.isFrozen) {
|
|
198
|
-
if (isHighlight) {
|
|
199
|
-
classNames.push('highlight');
|
|
200
|
-
}
|
|
201
|
-
if (isEditPending) {
|
|
202
|
-
classNames.push('modified');
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
return {
|
|
206
|
-
...attributes,
|
|
207
|
-
className: classNames.join(' '),
|
|
208
|
-
content: stringValue
|
|
209
|
-
};
|
|
210
|
-
}
|
|
211
|
-
getHoverForChunk(span) {
|
|
212
|
-
const addressAsString = span.getAttribute('data-id');
|
|
213
|
-
if (addressAsString) {
|
|
214
|
-
const address = (0, util_1.hexStrToUnsignedLong)(addressAsString);
|
|
215
|
-
const { value } = this.composeByte(address, true);
|
|
216
|
-
const { value: inMemory } = this.composeByte(address, false);
|
|
217
|
-
const oldValue = this.previousBytes && this.composeByte(address, false, this.previousBytes).value;
|
|
218
|
-
const decimal = parseInt(value, 16);
|
|
219
|
-
const octal = decimal.toString(8).padStart(this.options.byteSize / 8, '0');
|
|
220
|
-
const UTF8 = String.fromCharCode(decimal);
|
|
221
|
-
const binary = this.getPaddedBinary(decimal);
|
|
222
|
-
const toSend = { hex: value, octal, binary, decimal };
|
|
223
|
-
if (UTF8) {
|
|
224
|
-
toSend.UTF8 = UTF8;
|
|
225
|
-
}
|
|
226
|
-
if (inMemory !== value) {
|
|
227
|
-
toSend['Current Value'] = inMemory;
|
|
228
|
-
}
|
|
229
|
-
if (oldValue !== undefined && oldValue !== value) {
|
|
230
|
-
toSend['Previous Value'] = oldValue;
|
|
231
|
-
}
|
|
232
|
-
return toSend;
|
|
233
|
-
}
|
|
234
|
-
return undefined;
|
|
235
|
-
}
|
|
236
|
-
composeByte(addressPlusArrayOffset, usePendingEdits, dataSource = this.memory.bytes) {
|
|
237
|
-
let value = '';
|
|
238
|
-
const offset = addressPlusArrayOffset.subtract(this.memory.address);
|
|
239
|
-
const chunksPerByte = this.options.byteSize / 8;
|
|
240
|
-
const startingChunkIndex = offset.subtract(offset.modulo(chunksPerByte));
|
|
241
|
-
const address = this.memory.address.add(startingChunkIndex.divide(chunksPerByte));
|
|
242
|
-
for (let i = 0; i < chunksPerByte; i += 1) {
|
|
243
|
-
const targetOffset = startingChunkIndex.add(i);
|
|
244
|
-
const targetChunk = this.getFromMapOrArray(targetOffset, usePendingEdits, dataSource);
|
|
245
|
-
value += targetChunk.padStart(2, '0');
|
|
246
|
-
}
|
|
247
|
-
return { address, value };
|
|
248
|
-
}
|
|
249
|
-
getFromMapOrArray(arrayOffset, usePendingEdits, dataSource = this.memory.bytes) {
|
|
250
|
-
var _a, _b;
|
|
251
|
-
let value = usePendingEdits ? this.pendingMemoryEdits.get(arrayOffset.add(this.memory.address).toString()) : undefined;
|
|
252
|
-
if (value === undefined) {
|
|
253
|
-
value = (_b = (_a = dataSource[arrayOffset.toInt()]) === null || _a === void 0 ? void 0 : _a.toString(16)) !== null && _b !== void 0 ? _b : '';
|
|
254
|
-
}
|
|
255
|
-
return value;
|
|
256
|
-
}
|
|
257
|
-
clearEdits(address) {
|
|
258
|
-
if (typeof address === 'number') {
|
|
259
|
-
this.pendingMemoryEdits.delete(address);
|
|
260
|
-
}
|
|
261
|
-
else {
|
|
262
|
-
this.pendingMemoryEdits.clear();
|
|
263
|
-
}
|
|
264
|
-
this.update();
|
|
265
|
-
}
|
|
266
|
-
createUniqueEdits() {
|
|
267
|
-
const addressesSubmitted = new Set();
|
|
268
|
-
const edits = [];
|
|
269
|
-
for (const k of this.pendingMemoryEdits.keys()) {
|
|
270
|
-
const address = Long.fromString(k);
|
|
271
|
-
const { address: addressToSend, value: valueToSend } = this.composeByte(address, true);
|
|
272
|
-
const memoryReference = '0x' + addressToSend.toString(16);
|
|
273
|
-
if (!addressesSubmitted.has(memoryReference)) {
|
|
274
|
-
const data = Buffer.from(valueToSend, 'hex').toString('base64');
|
|
275
|
-
edits.push([k, { memoryReference, data }]);
|
|
276
|
-
addressesSubmitted.add(memoryReference);
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
return edits;
|
|
280
|
-
}
|
|
281
|
-
doWriteMemory(writeMemoryArgs) {
|
|
282
|
-
return this.memoryProvider.writeMemory(writeMemoryArgs);
|
|
283
|
-
}
|
|
284
|
-
showWriteError(location, error) {
|
|
285
|
-
if (this.currentErrorTimeout !== undefined) {
|
|
286
|
-
clearTimeout(this.currentErrorTimeout);
|
|
287
|
-
}
|
|
288
|
-
this.writeErrorInfo = { location, error };
|
|
289
|
-
this.update();
|
|
290
|
-
this.currentErrorTimeout = window.setTimeout(() => this.hideWriteError(), memory_widget_utils_1.Constants.ERROR_TIMEOUT);
|
|
291
|
-
}
|
|
292
|
-
hideWriteError() {
|
|
293
|
-
this.currentErrorTimeout = undefined;
|
|
294
|
-
this.writeErrorInfo = undefined;
|
|
295
|
-
this.update();
|
|
296
|
-
}
|
|
297
|
-
getWrapperHandlers() {
|
|
298
|
-
return this.options.isFrozen
|
|
299
|
-
? super.getWrapperHandlers()
|
|
300
|
-
: {
|
|
301
|
-
onClick: this.handleTableClick,
|
|
302
|
-
onContextMenu: this.handleTableRightClick,
|
|
303
|
-
onKeyDown: this.handleTableInput,
|
|
304
|
-
onMouseMove: this.handleTableMouseMove,
|
|
305
|
-
};
|
|
306
|
-
}
|
|
307
|
-
doHandleTableRightClick(event) {
|
|
308
|
-
var _a, _b;
|
|
309
|
-
const target = event.target;
|
|
310
|
-
if ((_a = target.classList) === null || _a === void 0 ? void 0 : _a.contains('eight-bits')) {
|
|
311
|
-
this.highlightedField = (0, util_1.hexStrToUnsignedLong)((_b = target.getAttribute('data-id')) !== null && _b !== void 0 ? _b : '-0x1');
|
|
312
|
-
}
|
|
313
|
-
super.doHandleTableRightClick(event);
|
|
314
|
-
}
|
|
315
|
-
isInBounds(candidateAddress) {
|
|
316
|
-
const { address, bytes } = this.memory;
|
|
317
|
-
return candidateAddress.greaterThanOrEqual(address) &&
|
|
318
|
-
candidateAddress.lessThan(address.add(bytes.length));
|
|
319
|
-
}
|
|
320
|
-
};
|
|
321
|
-
MemoryEditableTableWidget = __decorate([
|
|
322
|
-
(0, inversify_1.injectable)()
|
|
323
|
-
], MemoryEditableTableWidget);
|
|
324
|
-
exports.MemoryEditableTableWidget = MemoryEditableTableWidget;
|
|
1
|
+
"use strict";
|
|
2
|
+
/********************************************************************************
|
|
3
|
+
* Copyright (C) 2021 Ericsson and others.
|
|
4
|
+
*
|
|
5
|
+
* This program and the accompanying materials are made available under the
|
|
6
|
+
* terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
* http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
*
|
|
9
|
+
* This Source Code may also be made available under the following Secondary
|
|
10
|
+
* Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
* with the GNU Classpath Exception which is available at
|
|
13
|
+
* https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
*
|
|
15
|
+
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
********************************************************************************/
|
|
17
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
21
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
+
};
|
|
23
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
+
exports.MemoryEditableTableWidget = exports.EditableMemoryWidget = void 0;
|
|
25
|
+
const browser_1 = require("@theia/core/lib/browser");
|
|
26
|
+
const promise_util_1 = require("@theia/core/lib/common/promise-util");
|
|
27
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
28
|
+
const React = require("@theia/core/shared/react");
|
|
29
|
+
const Long = require("long");
|
|
30
|
+
const util_1 = require("../../common/util");
|
|
31
|
+
const memory_table_widget_1 = require("../memory-widget/memory-table-widget");
|
|
32
|
+
const memory_widget_utils_1 = require("../utils/memory-widget-utils");
|
|
33
|
+
const nls_1 = require("@theia/core/lib/common/nls");
|
|
34
|
+
var EditableMemoryWidget;
|
|
35
|
+
(function (EditableMemoryWidget) {
|
|
36
|
+
EditableMemoryWidget.ID = 'editable.memory.widget';
|
|
37
|
+
})(EditableMemoryWidget = exports.EditableMemoryWidget || (exports.EditableMemoryWidget = {}));
|
|
38
|
+
let MemoryEditableTableWidget = class MemoryEditableTableWidget extends memory_table_widget_1.MemoryTableWidget {
|
|
39
|
+
constructor() {
|
|
40
|
+
super(...arguments);
|
|
41
|
+
this.pendingMemoryEdits = new Map();
|
|
42
|
+
this.memoryEditsCompleted = new promise_util_1.Deferred();
|
|
43
|
+
this.highlightedField = Long.fromInt(-1);
|
|
44
|
+
this.doShowMoreMemoryBefore = false;
|
|
45
|
+
this.doShowMoreMemoryAfter = false;
|
|
46
|
+
this.handleClearEditClick = () => this.clearEdits();
|
|
47
|
+
this.submitMemoryEdits = async () => {
|
|
48
|
+
this.memoryEditsCompleted = new promise_util_1.Deferred();
|
|
49
|
+
let didUpdateMemory = false;
|
|
50
|
+
for (const [key, edit] of this.createUniqueEdits()) {
|
|
51
|
+
try {
|
|
52
|
+
await this.doWriteMemory(edit);
|
|
53
|
+
didUpdateMemory = true;
|
|
54
|
+
this.pendingMemoryEdits.delete(key);
|
|
55
|
+
}
|
|
56
|
+
catch (e) {
|
|
57
|
+
console.warn('Problem writing memory with arguments', edit, '\n', e);
|
|
58
|
+
const text = e instanceof Error ? e.message : 'Unknown error';
|
|
59
|
+
this.showWriteError(key, text);
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
this.memoryEditsCompleted.resolve();
|
|
64
|
+
if (didUpdateMemory) {
|
|
65
|
+
this.optionsWidget.fetchNewMemory();
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
this.handleTableClick = (event) => {
|
|
69
|
+
var _a, _b;
|
|
70
|
+
const target = event.target;
|
|
71
|
+
if ((_a = target.classList) === null || _a === void 0 ? void 0 : _a.contains('eight-bits')) {
|
|
72
|
+
this.highlightedField = (0, util_1.hexStrToUnsignedLong)((_b = target.getAttribute('data-id')) !== null && _b !== void 0 ? _b : '-0x1');
|
|
73
|
+
this.update();
|
|
74
|
+
event.stopPropagation();
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
this.handleTableInput = (event) => {
|
|
78
|
+
var _a, _b;
|
|
79
|
+
if (this.highlightedField.lessThan(0)) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
const keyCode = (_a = browser_1.KeyCode.createKeyCode(event.nativeEvent).key) === null || _a === void 0 ? void 0 : _a.keyCode;
|
|
83
|
+
const initialHighlight = this.highlightedField;
|
|
84
|
+
const initialHighlightIndex = initialHighlight.subtract(this.memory.address);
|
|
85
|
+
if (keyCode === browser_1.Key.TAB.keyCode) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const arrayElementsPerRow = (this.options.byteSize / 8) * this.options.bytesPerGroup * this.options.groupsPerRow;
|
|
89
|
+
const isAlreadyEdited = this.pendingMemoryEdits.has(this.highlightedField.toString());
|
|
90
|
+
const oldValue = (_b = this.pendingMemoryEdits.get(initialHighlight.toString())) !== null && _b !== void 0 ? _b : this.memory.bytes[initialHighlightIndex.toInt()].toString(16).padStart(2, '0');
|
|
91
|
+
let possibleNewHighlight = new Long(-1);
|
|
92
|
+
let newValue = oldValue;
|
|
93
|
+
switch (keyCode) {
|
|
94
|
+
case browser_1.Key.ARROW_DOWN.keyCode:
|
|
95
|
+
possibleNewHighlight = initialHighlight.add(arrayElementsPerRow);
|
|
96
|
+
event.preventDefault();
|
|
97
|
+
event.stopPropagation();
|
|
98
|
+
break;
|
|
99
|
+
case browser_1.Key.ARROW_UP.keyCode:
|
|
100
|
+
possibleNewHighlight = initialHighlight.greaterThan(arrayElementsPerRow) ? initialHighlight.subtract(arrayElementsPerRow) : possibleNewHighlight;
|
|
101
|
+
event.preventDefault();
|
|
102
|
+
event.stopPropagation();
|
|
103
|
+
break;
|
|
104
|
+
case browser_1.Key.ARROW_RIGHT.keyCode:
|
|
105
|
+
possibleNewHighlight = initialHighlight.add(1);
|
|
106
|
+
event.preventDefault();
|
|
107
|
+
event.stopPropagation();
|
|
108
|
+
break;
|
|
109
|
+
case browser_1.Key.ARROW_LEFT.keyCode:
|
|
110
|
+
possibleNewHighlight = initialHighlight.greaterThan(0) ? initialHighlight.subtract(1) : possibleNewHighlight;
|
|
111
|
+
break;
|
|
112
|
+
case browser_1.Key.BACKSPACE.keyCode:
|
|
113
|
+
newValue = oldValue.slice(0, oldValue.length - 1);
|
|
114
|
+
break;
|
|
115
|
+
case browser_1.Key.DELETE.keyCode:
|
|
116
|
+
newValue = '';
|
|
117
|
+
break;
|
|
118
|
+
case browser_1.Key.ENTER.keyCode:
|
|
119
|
+
this.submitMemoryEdits();
|
|
120
|
+
break;
|
|
121
|
+
case browser_1.Key.ESCAPE.keyCode:
|
|
122
|
+
if (isAlreadyEdited) {
|
|
123
|
+
this.clearEdits(this.highlightedField);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
this.clearEdits();
|
|
127
|
+
}
|
|
128
|
+
break;
|
|
129
|
+
default: {
|
|
130
|
+
const keyValue = parseInt(browser_1.KeyCode.createKeyCode(event.nativeEvent).toString(), 16);
|
|
131
|
+
if (!Number.isNaN(keyValue)) {
|
|
132
|
+
newValue = isAlreadyEdited ? oldValue : '';
|
|
133
|
+
if (newValue.length < 2) {
|
|
134
|
+
newValue += keyValue.toString(16);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
if (this.isInBounds(possibleNewHighlight)) {
|
|
140
|
+
this.highlightedField = possibleNewHighlight;
|
|
141
|
+
}
|
|
142
|
+
const valueWasChanged = newValue !== oldValue;
|
|
143
|
+
if (valueWasChanged) {
|
|
144
|
+
this.pendingMemoryEdits.set(this.highlightedField.toString(), newValue);
|
|
145
|
+
}
|
|
146
|
+
if (valueWasChanged || !this.highlightedField.equals(initialHighlight)) {
|
|
147
|
+
this.update();
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
async doInit() {
|
|
152
|
+
this.memoryEditsCompleted.resolve();
|
|
153
|
+
await super.doInit();
|
|
154
|
+
this.addClass('editable');
|
|
155
|
+
}
|
|
156
|
+
resetModifiedValue(valueAddress) {
|
|
157
|
+
const didChange = this.pendingMemoryEdits.delete(valueAddress.toString());
|
|
158
|
+
if (didChange) {
|
|
159
|
+
this.update();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
getState() {
|
|
163
|
+
super.getState();
|
|
164
|
+
if (!this.isInBounds(this.highlightedField)) {
|
|
165
|
+
this.highlightedField = this.memory.address;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
async handleMemoryChange(newMemory) {
|
|
169
|
+
await this.memoryEditsCompleted.promise;
|
|
170
|
+
if (newMemory.bytes.length === 0) {
|
|
171
|
+
this.pendingMemoryEdits.clear();
|
|
172
|
+
}
|
|
173
|
+
super.handleMemoryChange(newMemory);
|
|
174
|
+
}
|
|
175
|
+
areSameRegion(a, b) {
|
|
176
|
+
return b !== undefined && a.address.equals(b.address) && a.bytes.length === b.bytes.length;
|
|
177
|
+
}
|
|
178
|
+
getTableFooter() {
|
|
179
|
+
var _a, _b;
|
|
180
|
+
const showButtons = !!this.pendingMemoryEdits.size && !this.writeErrorInfo;
|
|
181
|
+
return ((showButtons || this.writeErrorInfo) && (React.createElement("div", { className: 'memory-edit-button-container' },
|
|
182
|
+
showButtons && React.createElement("button", { className: 'theia-button secondary', onClick: this.handleClearEditClick, type: 'reset', title: nls_1.nls.localize('theia/memory-inspector/editable/clear', 'Clear Changes') }, nls_1.nls.localize('theia/memory-inspector/editable/clear', 'Clear Changes')),
|
|
183
|
+
showButtons && React.createElement("button", { className: 'theia-button main', onClick: this.submitMemoryEdits, type: 'submit', title: nls_1.nls.localize('theia/memory-inspector/editable/apply', 'Apply Changes') }, nls_1.nls.localize('theia/memory-inspector/editable/apply', 'Apply Changes')),
|
|
184
|
+
!!this.writeErrorInfo && React.createElement("div", { className: 'memory-edit-error' },
|
|
185
|
+
React.createElement("div", { className: 'memory-edit-error-location' }, `Error writing to 0x${Long.fromString((_a = this.writeErrorInfo) === null || _a === void 0 ? void 0 : _a.location).toString(16)}`),
|
|
186
|
+
React.createElement("div", { className: 'memory-edit-error-details' }, (_b = this.writeErrorInfo) === null || _b === void 0 ? void 0 : _b.error)))));
|
|
187
|
+
}
|
|
188
|
+
getBitAttributes(arrayOffset, iteratee) {
|
|
189
|
+
var _a, _b, _c;
|
|
190
|
+
const attributes = super.getBitAttributes(arrayOffset, iteratee);
|
|
191
|
+
const classNames = (_b = (_a = attributes.className) === null || _a === void 0 ? void 0 : _a.split(' ')) !== null && _b !== void 0 ? _b : [];
|
|
192
|
+
const itemID = this.memory.address.add(arrayOffset);
|
|
193
|
+
const isHighlight = itemID.equals(this.highlightedField);
|
|
194
|
+
const isEditPending = this.pendingMemoryEdits.has(itemID.toString());
|
|
195
|
+
const padder = isHighlight && isEditPending ? '\xa0' : '0'; // non-breaking space so it doesn't look like plain whitespace.
|
|
196
|
+
const stringValue = ((_c = this.pendingMemoryEdits.get(itemID.toString())) !== null && _c !== void 0 ? _c : this.memory.bytes[arrayOffset].toString(16)).padStart(2, padder);
|
|
197
|
+
if (!this.options.isFrozen) {
|
|
198
|
+
if (isHighlight) {
|
|
199
|
+
classNames.push('highlight');
|
|
200
|
+
}
|
|
201
|
+
if (isEditPending) {
|
|
202
|
+
classNames.push('modified');
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
return {
|
|
206
|
+
...attributes,
|
|
207
|
+
className: classNames.join(' '),
|
|
208
|
+
content: stringValue
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
getHoverForChunk(span) {
|
|
212
|
+
const addressAsString = span.getAttribute('data-id');
|
|
213
|
+
if (addressAsString) {
|
|
214
|
+
const address = (0, util_1.hexStrToUnsignedLong)(addressAsString);
|
|
215
|
+
const { value } = this.composeByte(address, true);
|
|
216
|
+
const { value: inMemory } = this.composeByte(address, false);
|
|
217
|
+
const oldValue = this.previousBytes && this.composeByte(address, false, this.previousBytes).value;
|
|
218
|
+
const decimal = parseInt(value, 16);
|
|
219
|
+
const octal = decimal.toString(8).padStart(this.options.byteSize / 8, '0');
|
|
220
|
+
const UTF8 = String.fromCharCode(decimal);
|
|
221
|
+
const binary = this.getPaddedBinary(decimal);
|
|
222
|
+
const toSend = { hex: value, octal, binary, decimal };
|
|
223
|
+
if (UTF8) {
|
|
224
|
+
toSend.UTF8 = UTF8;
|
|
225
|
+
}
|
|
226
|
+
if (inMemory !== value) {
|
|
227
|
+
toSend['Current Value'] = inMemory;
|
|
228
|
+
}
|
|
229
|
+
if (oldValue !== undefined && oldValue !== value) {
|
|
230
|
+
toSend['Previous Value'] = oldValue;
|
|
231
|
+
}
|
|
232
|
+
return toSend;
|
|
233
|
+
}
|
|
234
|
+
return undefined;
|
|
235
|
+
}
|
|
236
|
+
composeByte(addressPlusArrayOffset, usePendingEdits, dataSource = this.memory.bytes) {
|
|
237
|
+
let value = '';
|
|
238
|
+
const offset = addressPlusArrayOffset.subtract(this.memory.address);
|
|
239
|
+
const chunksPerByte = this.options.byteSize / 8;
|
|
240
|
+
const startingChunkIndex = offset.subtract(offset.modulo(chunksPerByte));
|
|
241
|
+
const address = this.memory.address.add(startingChunkIndex.divide(chunksPerByte));
|
|
242
|
+
for (let i = 0; i < chunksPerByte; i += 1) {
|
|
243
|
+
const targetOffset = startingChunkIndex.add(i);
|
|
244
|
+
const targetChunk = this.getFromMapOrArray(targetOffset, usePendingEdits, dataSource);
|
|
245
|
+
value += targetChunk.padStart(2, '0');
|
|
246
|
+
}
|
|
247
|
+
return { address, value };
|
|
248
|
+
}
|
|
249
|
+
getFromMapOrArray(arrayOffset, usePendingEdits, dataSource = this.memory.bytes) {
|
|
250
|
+
var _a, _b;
|
|
251
|
+
let value = usePendingEdits ? this.pendingMemoryEdits.get(arrayOffset.add(this.memory.address).toString()) : undefined;
|
|
252
|
+
if (value === undefined) {
|
|
253
|
+
value = (_b = (_a = dataSource[arrayOffset.toInt()]) === null || _a === void 0 ? void 0 : _a.toString(16)) !== null && _b !== void 0 ? _b : '';
|
|
254
|
+
}
|
|
255
|
+
return value;
|
|
256
|
+
}
|
|
257
|
+
clearEdits(address) {
|
|
258
|
+
if (typeof address === 'number') {
|
|
259
|
+
this.pendingMemoryEdits.delete(address);
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.pendingMemoryEdits.clear();
|
|
263
|
+
}
|
|
264
|
+
this.update();
|
|
265
|
+
}
|
|
266
|
+
createUniqueEdits() {
|
|
267
|
+
const addressesSubmitted = new Set();
|
|
268
|
+
const edits = [];
|
|
269
|
+
for (const k of this.pendingMemoryEdits.keys()) {
|
|
270
|
+
const address = Long.fromString(k);
|
|
271
|
+
const { address: addressToSend, value: valueToSend } = this.composeByte(address, true);
|
|
272
|
+
const memoryReference = '0x' + addressToSend.toString(16);
|
|
273
|
+
if (!addressesSubmitted.has(memoryReference)) {
|
|
274
|
+
const data = Buffer.from(valueToSend, 'hex').toString('base64');
|
|
275
|
+
edits.push([k, { memoryReference, data }]);
|
|
276
|
+
addressesSubmitted.add(memoryReference);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
return edits;
|
|
280
|
+
}
|
|
281
|
+
doWriteMemory(writeMemoryArgs) {
|
|
282
|
+
return this.memoryProvider.writeMemory(writeMemoryArgs);
|
|
283
|
+
}
|
|
284
|
+
showWriteError(location, error) {
|
|
285
|
+
if (this.currentErrorTimeout !== undefined) {
|
|
286
|
+
clearTimeout(this.currentErrorTimeout);
|
|
287
|
+
}
|
|
288
|
+
this.writeErrorInfo = { location, error };
|
|
289
|
+
this.update();
|
|
290
|
+
this.currentErrorTimeout = window.setTimeout(() => this.hideWriteError(), memory_widget_utils_1.Constants.ERROR_TIMEOUT);
|
|
291
|
+
}
|
|
292
|
+
hideWriteError() {
|
|
293
|
+
this.currentErrorTimeout = undefined;
|
|
294
|
+
this.writeErrorInfo = undefined;
|
|
295
|
+
this.update();
|
|
296
|
+
}
|
|
297
|
+
getWrapperHandlers() {
|
|
298
|
+
return this.options.isFrozen
|
|
299
|
+
? super.getWrapperHandlers()
|
|
300
|
+
: {
|
|
301
|
+
onClick: this.handleTableClick,
|
|
302
|
+
onContextMenu: this.handleTableRightClick,
|
|
303
|
+
onKeyDown: this.handleTableInput,
|
|
304
|
+
onMouseMove: this.handleTableMouseMove,
|
|
305
|
+
};
|
|
306
|
+
}
|
|
307
|
+
doHandleTableRightClick(event) {
|
|
308
|
+
var _a, _b;
|
|
309
|
+
const target = event.target;
|
|
310
|
+
if ((_a = target.classList) === null || _a === void 0 ? void 0 : _a.contains('eight-bits')) {
|
|
311
|
+
this.highlightedField = (0, util_1.hexStrToUnsignedLong)((_b = target.getAttribute('data-id')) !== null && _b !== void 0 ? _b : '-0x1');
|
|
312
|
+
}
|
|
313
|
+
super.doHandleTableRightClick(event);
|
|
314
|
+
}
|
|
315
|
+
isInBounds(candidateAddress) {
|
|
316
|
+
const { address, bytes } = this.memory;
|
|
317
|
+
return candidateAddress.greaterThanOrEqual(address) &&
|
|
318
|
+
candidateAddress.lessThan(address.add(bytes.length));
|
|
319
|
+
}
|
|
320
|
+
};
|
|
321
|
+
MemoryEditableTableWidget = __decorate([
|
|
322
|
+
(0, inversify_1.injectable)()
|
|
323
|
+
], MemoryEditableTableWidget);
|
|
324
|
+
exports.MemoryEditableTableWidget = MemoryEditableTableWidget;
|
|
325
325
|
//# sourceMappingURL=memory-editable-table-widget.js.map
|