1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.isHandle = isHandle;
|
7 | exports.isNonPrimitiveHandle = isNonPrimitiveHandle;
|
8 | exports.constants = constants;
|
9 | exports.isSmallInt = isSmallInt;
|
10 | exports.encodeNegative = encodeNegative;
|
11 | exports.decodeNegative = decodeNegative;
|
12 | exports.encodePositive = encodePositive;
|
13 | exports.decodePositive = decodePositive;
|
14 | exports.encodeHandle = encodeHandle;
|
15 | exports.decodeHandle = decodeHandle;
|
16 | exports.encodeImmediate = encodeImmediate;
|
17 | exports.decodeImmediate = decodeImmediate;
|
18 |
|
19 | var _assert = require("./assert");
|
20 |
|
21 | function isHandle(value) {
|
22 | return value >= 0;
|
23 | }
|
24 |
|
25 | function isNonPrimitiveHandle(value) {
|
26 | return value > 3
|
27 | /* ENCODED_UNDEFINED_HANDLE */
|
28 | ;
|
29 | }
|
30 |
|
31 | function constants() {
|
32 | for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {
|
33 | values[_key] = arguments[_key];
|
34 | }
|
35 |
|
36 | return [false, true, null, undefined].concat(values);
|
37 | }
|
38 |
|
39 | function isSmallInt(value) {
|
40 | return value % 1 === 0 && value <= 536870911
|
41 | /* MAX_INT */
|
42 | && value >= -536870912
|
43 | /* MIN_INT */
|
44 | ;
|
45 | }
|
46 |
|
47 | function encodeNegative(num) {
|
48 | if (false
|
49 | /* LOCAL_DEBUG */
|
50 | ) {
|
51 | (0, _assert.debugAssert)(num % 1 === 0 && num >= -536870912
|
52 | /* MIN_INT */
|
53 | && num < 0, "Could not encode negative: " + num);
|
54 | }
|
55 |
|
56 | return num & -536870913
|
57 | /* SIGN_BIT */
|
58 | ;
|
59 | }
|
60 |
|
61 | function decodeNegative(num) {
|
62 | if (false
|
63 | /* LOCAL_DEBUG */
|
64 | ) {
|
65 | (0, _assert.debugAssert)(num % 1 === 0 && num < ~536870911
|
66 | /* MAX_INT */
|
67 | && num >= -1073741824
|
68 | /* MIN_SMI */
|
69 | , "Could not decode negative: " + num);
|
70 | }
|
71 |
|
72 | return num | ~-536870913
|
73 | /* SIGN_BIT */
|
74 | ;
|
75 | }
|
76 |
|
77 | function encodePositive(num) {
|
78 | if (false
|
79 | /* LOCAL_DEBUG */
|
80 | ) {
|
81 | (0, _assert.debugAssert)(num % 1 === 0 && num >= 0 && num <= 536870911
|
82 | /* MAX_INT */
|
83 | , "Could not encode positive: " + num);
|
84 | }
|
85 |
|
86 | return ~num;
|
87 | }
|
88 |
|
89 | function decodePositive(num) {
|
90 | if (false
|
91 | /* LOCAL_DEBUG */
|
92 | ) {
|
93 | (0, _assert.debugAssert)(num % 1 === 0 && num <= 0 && num >= ~536870911
|
94 | /* MAX_INT */
|
95 | , "Could not decode positive: " + num);
|
96 | }
|
97 |
|
98 | return ~num;
|
99 | }
|
100 |
|
101 | function encodeHandle(num) {
|
102 | if (false
|
103 | /* LOCAL_DEBUG */
|
104 | ) {
|
105 | (0, _assert.debugAssert)(num % 1 === 0 && num >= 0 && num <= 1073741823
|
106 | /* MAX_SMI */
|
107 | , "Could not encode handle: " + num);
|
108 | }
|
109 |
|
110 | return num;
|
111 | }
|
112 |
|
113 | function decodeHandle(num) {
|
114 | if (false
|
115 | /* LOCAL_DEBUG */
|
116 | ) {
|
117 | (0, _assert.debugAssert)(num % 1 === 0 && num <= 1073741823
|
118 | /* MAX_SMI */
|
119 | && num >= 0, "Could not decode handle: " + num);
|
120 | }
|
121 |
|
122 | return num;
|
123 | }
|
124 |
|
125 | function encodeImmediate(num) {
|
126 | num |= 0;
|
127 | return num < 0 ? encodeNegative(num) : encodePositive(num);
|
128 | }
|
129 |
|
130 | function decodeImmediate(num) {
|
131 | num |= 0;
|
132 | return num > -536870913
|
133 | /* SIGN_BIT */
|
134 | ? decodePositive(num) : decodeNegative(num);
|
135 | } // Warm
|
136 |
|
137 |
|
138 | [1, 2, 3].forEach(function (x) {
|
139 | return decodeHandle(encodeHandle(x));
|
140 | });
|
141 | [1, -1].forEach(function (x) {
|
142 | return decodeImmediate(encodeImmediate(x));
|
143 | });
|
144 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/util/lib/immediate.ts"],"names":[],"mappings":"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","sourcesContent":["import { LOCAL_DEBUG } from '@glimmer/local-debug-flags';\nimport { debugAssert as assert } from './assert';\n\n/*\n  Encoding notes\n\n  We use 30 bit integers for encoding, so that we don't ever encode a non-SMI\n  integer to push on the stack.\n\n  Handles are >= 0\n  Immediates are < 0\n\n  True, False, Undefined and Null are pushed as handles into the symbol table,\n  with well known handles (0, 1, 2, 3)\n\n  The negative space is divided into positives and negatives. Positives are\n  higher numbers (-1, -2, -3, etc), negatives are lower.\n\n  We only encode immediates for two reasons:\n\n  1. To transfer over the wire, so they're smaller in general\n  2. When pushing values onto the stack from the low level/inner VM, which may\n     be converted into WASM one day.\n\n  This allows the low-level VM to always use SMIs, and to minimize using JS\n  values via handles for things like the stack pointer and frame pointer.\n  Externally, most code pushes values as JS values, except when being pulled\n  from the append byte code where it was already encoded.\n\n  Logically, this is because the low level VM doesn't really care about these\n  higher level values. For instance, the result of a userland helper may be a\n  number, or a boolean, or undefined/null, but it's extra work to figure that\n  out and push it correctly, vs. just pushing the value as a JS value with a\n  handle.\n\n  Note: The details could change here in the future, this is just the current\n  strategy.\n*/\n\nexport const enum ImmediateConstants {\n  MAX_SMI = 2 ** 30 - 1,\n  MIN_SMI = ~MAX_SMI,\n  SIGN_BIT = ~(2 ** 29),\n  MAX_INT = ~SIGN_BIT - 1,\n  MIN_INT = ~MAX_INT,\n\n  FALSE_HANDLE = 0,\n  TRUE_HANDLE = 1,\n  NULL_HANDLE = 2,\n  UNDEFINED_HANDLE = 3,\n\n  ENCODED_FALSE_HANDLE = FALSE_HANDLE,\n  ENCODED_TRUE_HANDLE = TRUE_HANDLE,\n  ENCODED_NULL_HANDLE = NULL_HANDLE,\n  ENCODED_UNDEFINED_HANDLE = UNDEFINED_HANDLE,\n}\n\nexport function isHandle(value: number) {\n  return value >= 0;\n}\n\nexport function isNonPrimitiveHandle(value: number) {\n  return value > ImmediateConstants.ENCODED_UNDEFINED_HANDLE;\n}\n\nexport function constants(...values: unknown[]): unknown[] {\n  return [false, true, null, undefined, ...values];\n}\n\nexport function isSmallInt(value: number) {\n  return (\n    value % 1 === 0 && value <= ImmediateConstants.MAX_INT && value >= ImmediateConstants.MIN_INT\n  );\n}\n\nexport function encodeNegative(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= ImmediateConstants.MIN_INT && num < 0,\n      `Could not encode negative: ${num}`\n    );\n  }\n\n  return num & ImmediateConstants.SIGN_BIT;\n}\n\nexport function decodeNegative(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num < ~ImmediateConstants.MAX_INT && num >= ImmediateConstants.MIN_SMI,\n      `Could not decode negative: ${num}`\n    );\n  }\n\n  return num | ~ImmediateConstants.SIGN_BIT;\n}\n\nexport function encodePositive(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= 0 && num <= ImmediateConstants.MAX_INT,\n      `Could not encode positive: ${num}`\n    );\n  }\n\n  return ~num;\n}\n\nexport function decodePositive(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num <= 0 && num >= ~ImmediateConstants.MAX_INT,\n      `Could not decode positive: ${num}`\n    );\n  }\n\n  return ~num;\n}\n\nexport function encodeHandle(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= 0 && num <= ImmediateConstants.MAX_SMI,\n      `Could not encode handle: ${num}`\n    );\n  }\n\n  return num;\n}\n\nexport function decodeHandle(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num <= ImmediateConstants.MAX_SMI && num >= 0,\n      `Could not decode handle: ${num}`\n    );\n  }\n\n  return num;\n}\n\nexport function encodeImmediate(num: number) {\n  num |= 0;\n  return num < 0 ? encodeNegative(num) : encodePositive(num);\n}\n\nexport function decodeImmediate(num: number) {\n  num |= 0;\n  return num > ImmediateConstants.SIGN_BIT ? decodePositive(num) : decodeNegative(num);\n}\n\n// Warm\n[1, 2, 3].forEach(x => decodeHandle(encodeHandle(x)));\n[1, -1].forEach(x => decodeImmediate(encodeImmediate(x)));\n"],"sourceRoot":""} |
\ | No newline at end of file |