Skip to content

Commit

Permalink
fix: various fixes (#812)
Browse files Browse the repository at this point in the history
* fix: useMapType optionalAlternative

* fix: fix long and bigint with maps
  • Loading branch information
davidzeng0 authored Mar 27, 2023
1 parent 1615ae0 commit ca18495
Show file tree
Hide file tree
Showing 18 changed files with 944 additions and 20 deletions.
24 changes: 24 additions & 0 deletions integration/map-bigint-optional/maps-test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import { MapBigInt } from './test'

describe('maps-test', () => {
it('works with bigints', () => {
const test = MapBigInt.fromJSON({
map: {
1: 2,
3: 4
}
});

expect(test).toEqual({
map: new Map([
[BigInt(1), BigInt(2)],
[BigInt(3), BigInt(4)]
])
})

const data = MapBigInt.encode(test).finish();
const result = MapBigInt.decode(data);

expect(result).toEqual(test);
});
})
1 change: 1 addition & 0 deletions integration/map-bigint-optional/parameters.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
useOptionals=all,unknownFields=true,initializeFieldsAsUndefined=false,useMapType=true,forceLong=bigint
Binary file added integration/map-bigint-optional/test.bin
Binary file not shown.
5 changes: 5 additions & 0 deletions integration/map-bigint-optional/test.proto
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
syntax = "proto2";

message MapBigInt{
map<fixed64, int64> map = 1;
}
256 changes: 256 additions & 0 deletions integration/map-bigint-optional/test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,256 @@
/* eslint-disable */
import * as Long from "long";
import * as _m0 from "protobufjs/minimal";

export const protobufPackage = "";

export interface MapBigInt {
map?: Map<bigint, bigint>;
_unknownFields?: { [key: number]: Uint8Array[] };
}

export interface MapBigInt_MapEntry {
key: bigint;
value: bigint;
_unknownFields?: { [key: number]: Uint8Array[] };
}

function createBaseMapBigInt(): MapBigInt {
return {};
}

export const MapBigInt = {
encode(message: MapBigInt, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
(message.map || new Map()).forEach((value, key) => {
MapBigInt_MapEntry.encode({ key: key as any, value }, writer.uint32(10).fork()).ldelim();
});
if (message._unknownFields !== undefined) {
for (const key in message._unknownFields) {
const values = message._unknownFields[key];
const tag = parseInt(key, 10);
for (const value of values) {
writer.uint32(tag);
(writer as any)["_push"](
(val: Uint8Array, buf: Buffer, pos: number) => buf.set(val, pos),
value.length,
value,
);
}
}
}
return writer;
},

decode(input: _m0.Reader | Uint8Array, length?: number): MapBigInt {
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseMapBigInt();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
if (tag != 10) {
break;
}

const entry1 = MapBigInt_MapEntry.decode(reader, reader.uint32());
if (entry1.value !== undefined) {
if (message.map === undefined) {
message.map = new Map();
}

message.map!.set(entry1.key, entry1.value);
}
continue;
}
if ((tag & 7) == 4 || tag == 0) {
break;
}
const startPos = reader.pos;
reader.skipType(tag & 7);
const buf = reader.buf.slice(startPos, reader.pos);

if (message._unknownFields === undefined) {
message._unknownFields = {};
}

const list = message._unknownFields[tag];

if (list === undefined) {
message._unknownFields[tag] = [buf];
} else {
list.push(buf);
}
}
return message;
},

fromJSON(object: any): MapBigInt {
return {
map: isObject(object.map)
? Object.entries(object.map).reduce<Map<bigint, bigint>>((acc, [key, value]) => {
acc.set(BigInt(key), BigInt(value as string | number | bigint | boolean));
return acc;
}, new Map())
: new Map(),
};
},

toJSON(message: MapBigInt): unknown {
const obj: any = {};
obj.map = {};
if (message.map) {
message.map.forEach((v, k) => {
obj.map[k.toString()] = v.toString();
});
}
return obj;
},

create<I extends Exact<DeepPartial<MapBigInt>, I>>(base?: I): MapBigInt {
return MapBigInt.fromPartial(base ?? {});
},

fromPartial<I extends Exact<DeepPartial<MapBigInt>, I>>(object: I): MapBigInt {
const message = createBaseMapBigInt();
message.map = (() => {
const m = new Map();
(object.map as Map<bigint, bigint> ?? new Map()).forEach((value, key) => {
if (value !== undefined) {
m.set(key, BigInt(value as string | number | bigint | boolean));
}
});
return m;
})();
return message;
},
};

function createBaseMapBigInt_MapEntry(): MapBigInt_MapEntry {
return { key: BigInt("0"), value: BigInt("0") };
}

export const MapBigInt_MapEntry = {
encode(message: MapBigInt_MapEntry, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
if (message.key !== BigInt("0")) {
writer.uint32(9).fixed64(message.key.toString());
}
if (message.value !== BigInt("0")) {
writer.uint32(16).int64(message.value.toString());
}
if (message._unknownFields !== undefined) {
for (const key in message._unknownFields) {
const values = message._unknownFields[key];
const tag = parseInt(key, 10);
for (const value of values) {
writer.uint32(tag);
(writer as any)["_push"](
(val: Uint8Array, buf: Buffer, pos: number) => buf.set(val, pos),
value.length,
value,
);
}
}
}
return writer;
},

decode(input: _m0.Reader | Uint8Array, length?: number): MapBigInt_MapEntry {
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseMapBigInt_MapEntry();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
if (tag != 9) {
break;
}

message.key = longToBigint(reader.fixed64() as Long);
continue;
case 2:
if (tag != 16) {
break;
}

message.value = longToBigint(reader.int64() as Long);
continue;
}
if ((tag & 7) == 4 || tag == 0) {
break;
}
const startPos = reader.pos;
reader.skipType(tag & 7);
const buf = reader.buf.slice(startPos, reader.pos);

if (message._unknownFields === undefined) {
message._unknownFields = {};
}

const list = message._unknownFields[tag];

if (list === undefined) {
message._unknownFields[tag] = [buf];
} else {
list.push(buf);
}
}
return message;
},

fromJSON(object: any): MapBigInt_MapEntry {
return {
key: isSet(object.key) ? BigInt(object.key) : BigInt("0"),
value: isSet(object.value) ? BigInt(object.value) : BigInt("0"),
};
},

toJSON(message: MapBigInt_MapEntry): unknown {
const obj: any = {};
message.key !== undefined && (obj.key = message.key.toString());
message.value !== undefined && (obj.value = message.value.toString());
return obj;
},

create<I extends Exact<DeepPartial<MapBigInt_MapEntry>, I>>(base?: I): MapBigInt_MapEntry {
return MapBigInt_MapEntry.fromPartial(base ?? {});
},

fromPartial<I extends Exact<DeepPartial<MapBigInt_MapEntry>, I>>(object: I): MapBigInt_MapEntry {
const message = createBaseMapBigInt_MapEntry();
message.key = object.key ?? BigInt("0");
message.value = object.value ?? BigInt("0");
return message;
},
};

type Builtin = Date | Function | Uint8Array | string | number | boolean | bigint | undefined;

export type DeepPartial<T> = T extends Builtin ? T
: T extends Array<infer U> ? Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>>
: T extends {} ? { [K in keyof T]?: DeepPartial<T[K]> }
: Partial<T>;

type KeysOfUnion<T> = T extends T ? keyof T : never;
export type Exact<P, I extends P> = P extends Builtin ? P
: P & { [K in keyof P]: Exact<P[K], I[K]> } & { [K in Exclude<keyof I, KeysOfUnion<P>>]: never };

function longToBigint(long: Long) {
return BigInt(long.toString());
}

// If you get a compile-error about 'Constructor<Long> and ... have no overlap',
// add '--ts_proto_opt=esModuleInterop=true' as a flag when calling 'protoc'.
if (_m0.util.Long !== Long) {
_m0.util.Long = Long as any;
_m0.configure();
}

function isObject(value: any): boolean {
return typeof value === "object" && value !== null;
}

function isSet(value: any): boolean {
return value !== null && value !== undefined;
}
30 changes: 30 additions & 0 deletions integration/map-long-optional/maps-test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import Long = require('long');
import { MapBigInt } from './test'

describe('maps-test', () => {
it('works with bigints', () => {
const test = MapBigInt.fromJSON({
map: {
1: 2,
3: 4
}
});

expect(test).toEqual({
map: new Map([
[new Long(1, 0, false), new Long(2, 0, false)],
[new Long(3, 0, false), new Long(4, 0, false)]
])
});

const data = MapBigInt.encode(test).finish();
const result = MapBigInt.decode(data);

expect(result).toEqual({
map: new Map([
[new Long(1, 0, true), new Long(2, 0, false)],
[new Long(3, 0, true), new Long(4, 0, false)]
])
});
});
})
1 change: 1 addition & 0 deletions integration/map-long-optional/parameters.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
useOptionals=all,unknownFields=true,initializeFieldsAsUndefined=false,useMapType=true,forceLong=long
Binary file added integration/map-long-optional/test.bin
Binary file not shown.
5 changes: 5 additions & 0 deletions integration/map-long-optional/test.proto
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
syntax = "proto2";

message MapBigInt{
map<fixed64, int64> map = 1;
}
Loading

0 comments on commit ca18495

Please sign in to comment.