Skip to content
This repository has been archived by the owner on Nov 24, 2021. It is now read-only.

Order objects consistent with 0.2.6 #96

Merged
merged 81 commits into from
Aug 19, 2020
Merged
Changes from 1 commit
Commits
Show all changes
81 commits
Select commit Hold shift + click to select a range
b497c3e
rewrote enums in TS
natenichols Jun 26, 2020
3bbef14
linted changes
natenichols Jun 26, 2020
045c13b
added resolveJSONModule
natenichols Jun 26, 2020
0f1788c
changed field to types instead of class
natenichols Jun 30, 2020
bdf13f7
renamed enums to definitions
natenichols Jun 30, 2020
e76e34f
renamed enums -> definitions
natenichols Jun 30, 2020
3446499
refactored binary-parser
natenichols Jun 30, 2020
4a93464
rewrote ./src/serdes
natenichols Jul 1, 2020
878cd2f
merged master into dev to stay up to date
natenichols Jul 1, 2020
c25f515
added documentation
natenichols Jul 1, 2020
62eca89
Changed definitions -> enums
natenichols Jul 1, 2020
af28355
changed parameter names
natenichols Jul 6, 2020
c095367
renamed arrays to bytesArray
natenichols Jul 6, 2020
7f594fd
updated readFieldValue() documentation
natenichols Jul 6, 2020
10942dc
Merge branch 'master' into dev
natenichols Jul 6, 2020
cb62ee0
added checking for type and field codes
natenichols Jul 6, 2020
a16441f
tested scenarios where type and field codes were invalid
natenichols Jul 6, 2020
e160c3a
added test where both field and type code out of range
natenichols Jul 6, 2020
941347b
resolved merge conflict
natenichols Jul 6, 2020
f24fd33
ran linter
natenichols Jul 7, 2020
577aa50
changed field back to nth
natenichols Jul 7, 2020
e6fe5a5
Merge branch 'master' into dev
natenichols Jul 7, 2020
8f98b22
refactored hash and all derived classes
natenichols Jul 8, 2020
cdf5b7d
refactored src/types/blob
natenichols Jul 8, 2020
0caec5e
doc-ed SerializedType
natenichols Jul 8, 2020
1d1e11a
doc-ed SerializedType
natenichols Jul 8, 2020
e0dbd9f
doc-ed SerializedType
natenichols Jul 8, 2020
47de9af
added documentation for types
natenichols Jul 8, 2020
8930f2a
changed toBeNull to toBeUndefined
natenichols Jul 8, 2020
6ad5e5c
Updated for Pull Request comments
natenichols Jul 9, 2020
b9e891d
added readonly to SerializeTypeClass.bytes
natenichols Jul 9, 2020
b2fd4f9
flagged _iso private
natenichols Jul 9, 2020
dfc5ead
refactored UInt and derived classes
natenichols Jul 10, 2020
598e511
Merge branch 'master' into dev
natenichols Jul 10, 2020
d264ac3
added docs
natenichols Jul 10, 2020
75734b2
made UInt abstract
natenichols Jul 10, 2020
a28e97d
refactored ./src/path-set
natenichols Jul 13, 2020
a77a2d2
linted code
natenichols Jul 13, 2020
fd082a3
removed linting comment
natenichols Jul 13, 2020
a79476d
added documenation for PathSet
natenichols Jul 13, 2020
baeae1e
merged master into dev
natenichols Jul 13, 2020
cce6fc0
removed a console.log that was used to debug
natenichols Jul 13, 2020
b7d3f9d
switching branches
natenichols Jul 13, 2020
6f98ea0
refactored for PR
natenichols Jul 13, 2020
13e2174
added brackets to if
natenichols Jul 13, 2020
8343c81
added linter to put space before comments
natenichols Jul 13, 2020
18d3416
merge branch working on STArray
natenichols Jul 13, 2020
4e09893
refactored STArray
natenichols Jul 14, 2020
7bb9bf8
documented STArray Class
natenichols Jul 14, 2020
6b2c66a
Merge branch 'dev' of https://github.com/ripple/ripple-binary-codec i…
natenichols Jul 14, 2020
92c9247
refactored Amount.ts
natenichols Jul 15, 2020
c07744d
switching branches
natenichols Jul 16, 2020
f34af9b
refactored STObject
natenichols Jul 16, 2020
58b0c4b
renamed base classes
natenichols Jul 16, 2020
b27d6c1
added .prototype to test
natenichols Jul 16, 2020
60588dd
merged stobject-refactor into dev
natenichols Jul 16, 2020
d08df74
Documented STObject class
natenichols Jul 16, 2020
9e4a6b4
removed commented out code
natenichols Jul 16, 2020
3ad960a
removed commented out code
natenichols Jul 16, 2020
efa7141
Merge branch 'dev' of https://github.com/ripple/ripple-binary-codec i…
natenichols Jul 16, 2020
e40cfa6
ran linter
natenichols Jul 16, 2020
4f95b78
changed string literals to constants
natenichols Jul 20, 2020
a9102f1
got rid of ./utils
natenichols Jul 20, 2020
55e39ef
finished refactor
natenichols Jul 21, 2020
0881fd0
merged master into dev
natenichols Jul 21, 2020
170abc9
updated exports
natenichols Jul 21, 2020
2728f31
updated exports
natenichols Jul 21, 2020
146e19d
removed partial application of function
natenichols Jul 21, 2020
fdaa576
removed unknown types
natenichols Jul 27, 2020
58a3569
documented index
natenichols Jul 28, 2020
1589c79
add JSON recursive type
natenichols Jul 29, 2020
57b4701
add JSON recursive type
natenichols Jul 29, 2020
f1301c1
Merge branch 'dev' of https://github.com/ripple/ripple-binary-codec i…
natenichols Jul 29, 2020
68b5aff
make .from methods accept generics
natenichols Jul 30, 2020
dc55040
Merge branch 'dev' of https://github.com/ripple/ripple-binary-codec i…
natenichols Jul 30, 2020
8a25d41
prepare for 1.0.0-rc1
natenichols Aug 18, 2020
f564c20
prepare for 1.0.0-rc1
natenichols Aug 18, 2020
5f3fbd4
version to 1.0.0-rc1
natenichols Aug 18, 2020
cd12341
modified API to take object types
natenichols Aug 18, 2020
23c381c
Update order of Hop and Amount objects
natenichols Aug 19, 2020
92e9ed1
update version to 1.0.0-rc3
natenichols Aug 19, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
rewrote ./src/serdes
natenichols committed Jul 1, 2020

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit 4a9346458080be89ae2bf140284bef8f1f03dbd9
8 changes: 4 additions & 4 deletions src/definitions/index.ts
Original file line number Diff line number Diff line change
@@ -9,7 +9,7 @@ const TRANSACTION_RESULT_WIDTH = 1;
/*
* @brief: Serialize a field based on type_code and Field.nth
*/
function fieldHeader(type: number, nth: number): Uint8Array {
function fieldHeader(type: number, nth: number): Buffer {
const header: Array<number> = [];
if (type < 16) {
if (nth < 16) {
@@ -22,7 +22,7 @@ function fieldHeader(type: number, nth: number): Uint8Array {
} else {
header.push(0, type, nth);
}
return new Uint8Array(header);
return Buffer.from(header);
}

/*
@@ -87,7 +87,7 @@ interface FieldInstance {
readonly type: Bytes;
readonly ordinal: number;
readonly name: string;
readonly header: Uint8Array;
readonly header: Buffer;
readonly associatedType: any;
}

@@ -137,4 +137,4 @@ const TransactionResult = new BytesLookup(
);
const Field = new FieldLookup(enums.FIELDS as Array<[string, FieldInfo]>);

export { Field, Type, LedgerEntryType, TransactionResult, TransactionType };
export { Field, FieldInstance, Type, LedgerEntryType, TransactionResult, TransactionType };
191 changes: 89 additions & 102 deletions src/serdes/binary-serializer.ts
Original file line number Diff line number Diff line change
@@ -1,110 +1,97 @@
import { strict as assert } from "assert";
import { parseBytes, bytesToHex } from "../utils/bytes-utils";
import { makeClass } from "../utils/make-class";
import { Field } from "../definitions";
import * as assert from "assert";
import { Field, FieldInstance } from "../definitions";

const BytesSink = {
put(/* bytesSequence */) {
// any hex string or any object with a `length` and where 0 <= [ix] <= 255
},
};
class BytesList {
arrays: Array<Buffer> = [];
length: number = 0;

put(bytesArg: Buffer): BytesList {
let bytes = Buffer.from(bytesArg) // Temporary, to catch isntances of Uint8Array being passed in
this.length += bytes.byteLength;
this.arrays.push(bytes);
return this;
}

const BytesList = makeClass(
{
implementing: BytesSink,
BytesList() {
this.arrays = [];
this.length = 0;
},
put(bytesArg) {
const bytes = parseBytes(bytesArg, Uint8Array);
this.length += bytes.length;
this.arrays.push(bytes);
return this;
},
toBytesSink(sink) {
this.arrays.forEach((arr) => {
sink.put(arr);
});
},
toBytes() {
const concatenated = new Uint8Array(this.length);
let pointer = 0;
this.arrays.forEach((arr) => {
concatenated.set(arr, pointer);
pointer += arr.length;
});
return concatenated;
},
toHex() {
return bytesToHex(this.toBytes());
},
},
undefined
);
toBytesSink(sink: BytesList): void {
sink.put(this.toBytes());
}

const BinarySerializer = makeClass(
{
BinarySerializer(sink) {
this.sink = sink;
},
write(value) {
toBytes(): Buffer {
return Buffer.concat(this.arrays)
}

toHex(): string {
return this.toBytes().toString('hex').toUpperCase();
}
}

class BinarySerializer {
sink: BytesList = new BytesList()

constructor(sink: BytesList) {
this.sink = sink;
}

write(value): void {
value.toBytesSink(this.sink);
}

put(bytes: Buffer): void {
this.sink.put(bytes);
}

writeType(type, value): void {
this.write(type.from(value));
}

writeBytesList(bl: BytesList): void {
bl.toBytesSink(this.sink);
}

encodeVL(len: number): Buffer {
let length = len;
const lenBytes = Buffer.alloc(3);
if (length <= 192) {
lenBytes[0] = length;
return lenBytes.slice(0, 1);
} else if (length <= 12480) {
length -= 193;
lenBytes[0] = 193 + (length >>> 8);
lenBytes[1] = length & 0xff;
return lenBytes.slice(0, 2);
} else if (length <= 918744) {
length -= 12481;
lenBytes[0] = 241 + (length >>> 16);
lenBytes[1] = (length >> 8) & 0xff;
lenBytes[2] = length & 0xff;
return lenBytes.slice(0, 3);
}
throw new Error("Overflow error");
}

writeFieldAndValue(field: FieldInstance, _value): void {
const value = field.associatedType.from(_value);
assert(value.toBytesSink, field.name);
this.sink.put(field.header);

if (field.isVariableLengthEncoded) {
this.writeLengthEncoded(value);
} else {
value.toBytesSink(this.sink);
},
put(bytes) {
this.sink.put(bytes);
},
writeType(type, value) {
this.write(type.from(value));
},
writeBytesList(bl) {
bl.toBytesSink(this.sink);
},
encodeVL(len) {
let length = len;
const lenBytes = new Uint8Array(4);
if (length <= 192) {
lenBytes[0] = length;
return lenBytes.subarray(0, 1);
} else if (length <= 12480) {
length -= 193;
lenBytes[0] = 193 + (length >>> 8);
lenBytes[1] = length & 0xff;
return lenBytes.subarray(0, 2);
} else if (length <= 918744) {
length -= 12481;
lenBytes[0] = 241 + (length >>> 16);
lenBytes[1] = (length >> 8) & 0xff;
lenBytes[2] = length & 0xff;
return lenBytes.subarray(0, 3);
if (field.type.name === "STObject") {
this.sink.put(Field["ObjectEndMarker"].header);
} else if (field.type.name === "STArray") {
this.sink.put(Field["ArrayEndMarker"].header);
}
throw new Error("Overflow error");
},
writeFieldAndValue(field, _value) {
const sink = this.sink;
const value = field.associatedType.from(_value);
assert(value.toBytesSink, field);
sink.put(field.header);
}
}

if (field.isVariableLengthEncoded) {
this.writeLengthEncoded(value);
} else {
value.toBytesSink(sink);
if (field.type.name === "STObject") {
sink.put(Field["ObjectEndMarker"].header);
} else if (field.type.name === "STArray") {
sink.put(Field["ArrayEndMarker"].header);
}
}
},
writeLengthEncoded(value) {
const bytes = new BytesList();
value.toBytesSink(bytes);
this.put(this.encodeVL(bytes.length));
this.writeBytesList(bytes);
},
},
undefined
);
writeLengthEncoded(value): void {
const bytes = new BytesList();
value.toBytesSink(bytes);
this.put(this.encodeVL(bytes.length));
this.writeBytesList(bytes);
}
}

export { BytesList, BinarySerializer };
11 changes: 5 additions & 6 deletions test/binary-parser.test.js
Original file line number Diff line number Diff line change
@@ -37,13 +37,12 @@ function basicApiTests () {
const bytes = parseHexOnly('00,01020304,0506', Uint8Array)
test('can read slices of bytes', () => {
const parser = makeParser(bytes)
expect(parser.pos()).toBe(0)
expect(parser._buf instanceof Uint8Array).toBe(true)
expect(parser._buf instanceof Buffer).toBe(true)
const read1 = parser.read(1)
expect(read1 instanceof Uint8Array).toBe(true)
expect(read1).toEqual(Uint8Array.from([0]))
expect(parser.read(4)).toEqual(Uint8Array.from([1, 2, 3, 4]))
expect(parser.read(2)).toEqual(Uint8Array.from([5, 6]))
expect(read1 instanceof Buffer).toBe(true)
expect(read1).toEqual(Buffer.from([0]))
expect(parser.read(4)).toEqual(Buffer.from([1, 2, 3, 4]))
expect(parser.read(2)).toEqual(Buffer.from([5, 6]))
expect(() => parser.read(1)).toThrow()
})
test('can read a Uint32 at full', () => {
12 changes: 6 additions & 6 deletions test/binary-serializer.test.js
Original file line number Diff line number Diff line change
@@ -52,18 +52,18 @@ const PaymentChannel = {
}

function bytesListTest () {
const list = new BytesList().put([0]).put([2, 3]).put([4, 5])
test('is an Array<Uint8Array>', function () {
const list = new BytesList().put(Buffer.from([0])).put(Buffer.from([2, 3])).put(Buffer.from([4, 5]))
test('is an Array<Buffer>', function () {
expect(Array.isArray(list.arrays)).toBe(true)
expect(list.arrays[0] instanceof Uint8Array).toBe(true)
expect(list.arrays[0] instanceof Buffer).toBe(true)
})
test('keeps track of the length itself', function () {
expect(list).toHaveLength(5)
expect(list.length).toBe(5)
})
test('can join all arrays into one via toBytes', function () {
const joined = list.toBytes()
expect(joined).toHaveLength(5)
expect(joined).toEqual(Uint8Array.from([0, 2, 3, 4, 5]))
expect(joined).toEqual(Buffer.from([0, 2, 3, 4, 5]))
})
}

@@ -95,7 +95,7 @@ function check (type, n, expected) {
return
}
serializer.writeType(type, n)
expect(bl.toBytes()).toEqual(Uint8Array.from(expected))
expect(bl.toBytes()).toEqual(Buffer.from(expected))
})
}

2 changes: 1 addition & 1 deletion test/fixtures/data-driven-tests.json
Original file line number Diff line number Diff line change
@@ -943,7 +943,7 @@
"name": "TickSize",
"nth_of_type": 16,
"type": 16,
"expected_hex": "01010"
"expected_hex": "001010"
}
],
"whole_objects": [