@muze-nl/od-jsontag 0.2.0 → 0.2.2
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/package.json +1 -1
- package/src/parse.mjs +9 -2
- package/src/serialize.mjs +24 -18
- package/src/symbols.mjs +1 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@muze-nl/od-jsontag",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.2",
|
|
4
4
|
"description": "On Demand JSONTag: parse/serialize large datastructures on demand, useful for sharing data between threads",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"author": "Auke van Slooten <auke@muze.nl>",
|
package/src/parse.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import JSONTag from '@muze-nl/jsontag';
|
|
2
2
|
import Null from '@muze-nl/jsontag/src/lib/Null.mjs'
|
|
3
3
|
import serialize from './serialize.mjs'
|
|
4
|
-
import {source,isProxy,getBuffer,getIndex,isChanged,isParsed,position,parent,resultSet} from './symbols.mjs'
|
|
4
|
+
import {source,isProxy,proxyType,getBuffer,getIndex,isChanged,isParsed,position,parent,resultSet} from './symbols.mjs'
|
|
5
5
|
|
|
6
6
|
const decoder = new TextDecoder()
|
|
7
7
|
const encoder = new TextEncoder()
|
|
@@ -731,6 +731,9 @@ export default function parse(input, meta, immutable=true)
|
|
|
731
731
|
case isProxy:
|
|
732
732
|
return true
|
|
733
733
|
break
|
|
734
|
+
case proxyType:
|
|
735
|
+
return 'new'
|
|
736
|
+
break
|
|
734
737
|
case getBuffer:
|
|
735
738
|
return (i) => {
|
|
736
739
|
let index = target[getIndex]
|
|
@@ -845,6 +848,9 @@ export default function parse(input, meta, immutable=true)
|
|
|
845
848
|
case isProxy:
|
|
846
849
|
return true
|
|
847
850
|
break
|
|
851
|
+
case proxyType:
|
|
852
|
+
return 'parse'
|
|
853
|
+
break
|
|
848
854
|
case getBuffer:
|
|
849
855
|
return (i) => {
|
|
850
856
|
let index = target[getIndex]
|
|
@@ -887,6 +893,7 @@ export default function parse(input, meta, immutable=true)
|
|
|
887
893
|
resetObject(target)
|
|
888
894
|
target[position] = value[position]
|
|
889
895
|
target[isParsed] = false
|
|
896
|
+
target[isChanged] = false
|
|
890
897
|
return true
|
|
891
898
|
break
|
|
892
899
|
case resultSet:
|
|
@@ -1084,7 +1091,7 @@ export default function parse(input, meta, immutable=true)
|
|
|
1084
1091
|
offsetArray.push(at)
|
|
1085
1092
|
line = result[2]
|
|
1086
1093
|
if (result[1]) {
|
|
1087
|
-
if (!meta.resultArray[line]) {
|
|
1094
|
+
if (!meta.resultArray[line] || meta.resultArray[line][proxyType]=='new') {
|
|
1088
1095
|
meta.resultArray[line] = result[1]
|
|
1089
1096
|
} else {
|
|
1090
1097
|
meta.resultArray[line][source] = result[1]
|
package/src/serialize.mjs
CHANGED
|
@@ -15,17 +15,8 @@ function stringToSAB(strData) {
|
|
|
15
15
|
return uint8sab
|
|
16
16
|
}
|
|
17
17
|
|
|
18
|
-
export default function serialize(value,
|
|
18
|
+
export default function serialize(value, options={}) {
|
|
19
19
|
let resultArray = []
|
|
20
|
-
if (!meta) {
|
|
21
|
-
meta = {}
|
|
22
|
-
}
|
|
23
|
-
if (!meta.index) {
|
|
24
|
-
meta.index = {}
|
|
25
|
-
}
|
|
26
|
-
if (!meta.index.id) {
|
|
27
|
-
meta.index.id = new Map()
|
|
28
|
-
}
|
|
29
20
|
let references = new WeakMap()
|
|
30
21
|
|
|
31
22
|
function stringifyValue(value, inarray=false) {
|
|
@@ -139,7 +130,7 @@ export default function serialize(value, meta, skipLength=false, index=false) {
|
|
|
139
130
|
if (typeof s == 'string' || s instanceof String) {
|
|
140
131
|
s = encoder.encode(s)
|
|
141
132
|
}
|
|
142
|
-
if (skipLength) {
|
|
133
|
+
if (s[0]==43 || options.skipLength) {
|
|
143
134
|
return new Uint8Array(s)
|
|
144
135
|
}
|
|
145
136
|
let length = encoder.encode('('+s.length+')')
|
|
@@ -154,16 +145,31 @@ export default function serialize(value, meta, skipLength=false, index=false) {
|
|
|
154
145
|
} else {
|
|
155
146
|
resultArray.push(value)
|
|
156
147
|
}
|
|
157
|
-
let
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
148
|
+
let currentSource = 0
|
|
149
|
+
let currentResult = 0
|
|
150
|
+
let skipCount = 0
|
|
151
|
+
let result = resultArray
|
|
152
|
+
if (options.changes) {
|
|
153
|
+
result = []
|
|
154
|
+
}
|
|
155
|
+
while(currentSource<resultArray.length) {
|
|
156
|
+
if (resultArray[currentSource][isChanged] || !resultArray[currentSource][isProxy]) {
|
|
157
|
+
if (skipCount) {
|
|
158
|
+
result[currentResult] = encoder.encode('+'+skipCount)
|
|
159
|
+
skipCount = 0
|
|
160
|
+
currentResult++
|
|
161
|
+
}
|
|
162
|
+
result[currentResult] = encoder.encode(innerStringify(currentSource))
|
|
163
|
+
currentResult++
|
|
164
|
+
} else if (!options.changes) {
|
|
165
|
+
resultArray[currentResult] = resultArray[currentSource][getBuffer](currentSource)
|
|
166
|
+
currentResult++
|
|
161
167
|
} else {
|
|
162
|
-
|
|
168
|
+
skipCount++
|
|
163
169
|
}
|
|
164
|
-
|
|
170
|
+
currentSource++
|
|
165
171
|
}
|
|
166
|
-
let arr =
|
|
172
|
+
let arr = result.map(encode)
|
|
167
173
|
let length = 0
|
|
168
174
|
for (let line of arr) {
|
|
169
175
|
length += line.length+1
|
package/src/symbols.mjs
CHANGED