/
view-types.ts
88 lines (74 loc) · 2.93 KB
/
view-types.ts
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
/********************************************************************************
* Copyright (C) 2023 Ericsson, Arm and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/
import deepequal from 'fast-deep-equal';
import type * as React from 'react';
import { Endianness } from '../../common/manifest';
import { Memory } from '../../common/memory';
import { areRangesEqual, BigIntMemoryRange } from '../../common/memory-range';
import { ReadMemoryArguments } from '../../common/messaging';
import { MemoryDisplayConfiguration } from '../../common/webview-configuration';
export interface SerializedTableRenderOptions extends MemoryDisplayConfiguration {
columnOptions: Array<{ label: string, doRender: boolean }>;
endianness: Endianness;
effectiveAddressLength: number;
}
export interface Event<T> {
(handler: (event: T) => unknown): Disposable;
}
export interface Disposable { dispose(): unknown };
export function dispose(disposable: { dispose(): unknown }): void {
disposable.dispose();
}
export interface Decoration {
range: BigIntMemoryRange;
style: React.CSSProperties;
}
export function areDecorationsEqual(one: Decoration, other: Decoration): boolean {
return areRangesEqual(one.range, other.range) && deepequal(one.style, other.style);
}
export interface MemoryState {
/**
* The user configured memory read arguments
*/
configuredReadArguments: Required<ReadMemoryArguments>;
/**
* The active memory read arguments used to load the memory
*/
activeReadArguments: Required<ReadMemoryArguments>;
memory?: Memory;
isMemoryFetching: boolean;
}
export interface UpdateExecutor {
fetchData(currentViewParameters: ReadMemoryArguments): Promise<void>;
}
export interface StylableNodeAttributes {
className?: string;
style?: React.CSSProperties;
title?: string;
}
export interface FullNodeAttributes extends StylableNodeAttributes {
content: string;
}
export const AddressPaddingOptions = {
'Minimal': 'Minimal',
'Unpadded': 0,
'32bit': 32,
'64bit': 64,
} as const;
export type ReactInteraction<E extends Element = Element> = React.MouseEvent<E> | React.KeyboardEvent<E>;
export function isTrigger(event: ReactInteraction): boolean {
return !('code' in event) || event.code === 'Enter' || event.code === 'Space';
}