From 87b4d21c79b113dcdcf99ab0c94e8e6ab63e70e1 Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Wed, 6 Apr 2022 13:41:32 +0100 Subject: [PATCH 1/2] Make JsonRecord type safe --- docs/modules/Json.ts.md | 2 +- dtslint/ts3.5/Json.ts | 13 +++++++++---- package-lock.json | 2 +- src/Json.ts | 2 +- test/Json.ts | 1 + 5 files changed, 13 insertions(+), 7 deletions(-) diff --git a/docs/modules/Json.ts.md b/docs/modules/Json.ts.md index 2ecbffff8..cad3fc971 100644 --- a/docs/modules/Json.ts.md +++ b/docs/modules/Json.ts.md @@ -49,7 +49,7 @@ Added in v2.10.0 ```ts export interface JsonRecord { - readonly [key: string]: Json + readonly [key: string]: Json | undefined } ``` diff --git a/dtslint/ts3.5/Json.ts b/dtslint/ts3.5/Json.ts index 8e568d1c8..cca625564 100644 --- a/dtslint/ts3.5/Json.ts +++ b/dtslint/ts3.5/Json.ts @@ -2,6 +2,15 @@ import * as E from '../../src/Either' import { pipe } from '../../src/function' import * as _ from '../../src/Json' +declare const jr: _.JsonRecord + +// +// JsonRecord +// + +// $ExpectType string | number | boolean | JsonRecord | JsonArray | null | undefined +jr.foo + // // stringify // @@ -12,10 +21,6 @@ _.stringify<_.Json>(undefined) _.stringify<_.Json>(() => {}) // $ExpectError _.stringify<_.Json>(Symbol()) -// $ExpectError -_.stringify<_.Json>({ a: undefined }) -// $ExpectError -_.stringify<_.Json>({ ...{ a: undefined } }) // tslint:disable-next-line: interface-over-type-literal interface AB { diff --git a/package-lock.json b/package-lock.json index 9cf6fb658..487afcf03 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2350,7 +2350,7 @@ } }, "dtslint": { - "version": "github:gcanti/dtslint#2c3c3487e7650d6ca90c2877dbbd7c4c08360d0d", + "version": "github:gcanti/dtslint#ef28f0ad1d3bd64b8367f6f543cf6fd3b9b09c1b", "from": "github:gcanti/dtslint", "dev": true, "requires": { diff --git a/src/Json.ts b/src/Json.ts index 4a188af53..67b7a8632 100644 --- a/src/Json.ts +++ b/src/Json.ts @@ -13,7 +13,7 @@ export type Json = boolean | number | string | null | JsonArray | JsonRecord * @since 2.10.0 */ export interface JsonRecord { - readonly [key: string]: Json + readonly [key: string]: Json | undefined } /** diff --git a/test/Json.ts b/test/Json.ts index 060baf731..efcd243d7 100644 --- a/test/Json.ts +++ b/test/Json.ts @@ -11,6 +11,7 @@ describe('Json', () => { it('stringify', () => { U.deepStrictEqual(pipe({ a: 1 }, _.stringify), E.right('{"a":1}')) + U.deepStrictEqual(pipe({ a: undefined }, _.stringify), E.right('{}')) const circular: any = { ref: null } circular.ref = circular U.deepStrictEqual( From d5c593577cfec284557fbf2e72c5a3654bef460c Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Wed, 6 Apr 2022 14:11:07 +0100 Subject: [PATCH 2/2] Avoid differences in TS versions --- dtslint/ts3.5/Json.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/dtslint/ts3.5/Json.ts b/dtslint/ts3.5/Json.ts index cca625564..eb9056b50 100644 --- a/dtslint/ts3.5/Json.ts +++ b/dtslint/ts3.5/Json.ts @@ -8,8 +8,9 @@ declare const jr: _.JsonRecord // JsonRecord // -// $ExpectType string | number | boolean | JsonRecord | JsonArray | null | undefined -jr.foo +// $ExpectError +const foo1: _.Json = jr.foo +const foo2: _.Json | undefined = jr.foo // // stringify