New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@fgv/ts-utils

Package Overview
Dependencies
Maintainers
1
Versions
95
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@fgv/ts-utils - npm Package Compare versions

Comparing version 0.1.9 to 0.2.0

57

converter.d.ts
import { Result } from './result';
declare type OnError = 'failOnError' | 'ignoreErrors';
export interface Converter<T> {
/**
* Converts from unknown to <T>
* @param from The unknown to be converted
* @returns An @see Result with a value or an error message
*/
convert(from: unknown): Result<T>;
/**
* Converts from unknown to <T> or undefined, as appropriate.
* If 'onError' is 'failOnError', the converter succeeds for
* 'undefined' or any convertible value, but reports an error
* if it encounters a value that cannot be converted. If 'onError'
* is 'ignoreErrors' (default) then values that cannot be converted
* result in a successful return of 'undefined'.
* @param from The unknown to be converted
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
*/
convertOptional(from: unknown, onError?: OnError): Result<T | undefined>;
/**
* Creates a converter for an optional value. If 'onError'
* is 'failOnError', the converter accepts 'undefined' or a
* convertible value, but reports an error if it encounters
* a value that cannot be converted. If 'onError' is 'ignoreErrors'
* (default) then values that cannot be converted result in a
* successful return of 'undefined'.
*
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
* */
optional(onError?: OnError): Converter<T | undefined>;
/**
* Applies a (possibly) mapping conversion to the converted value.
* @param mapper A function which maps from the converted type to some other type.
*/
map<T2>(mapper: (from: T) => Result<T2>): Converter<T2>;
/**
* Applies an additional converter to the converted value.
* @param mapConverter The converter to be applied to the converted value
*/
mapConvert<T2>(mapConverter: Converter<T2>): Converter<T2>;
/**
* Creates a converter with an optional constraint. If the base converter
* succeeds, calls a supplied constraint evaluation function with the
* value and fails the conversion if the function returns either false
* or Failure<T>.
*
* @param constraint Constraint evaluation function
*/
withConstraint(constraint: (val: T) => boolean | Result<T>): Converter<T>;
}
/**
* Simple templated converter wrapper to simplify typed conversion from unknown.
*/
export declare class Converter<T> {
export declare class BaseConverter<T> implements Converter<T> {
private _converter;
constructor(converter: (from: unknown) => Result<T>);
constructor(converter: (from: unknown, self: Converter<T>) => Result<T>);
/**

@@ -23,3 +72,3 @@ * Converts from unknown to <T>

* @param from The unknown to be converted
* @param onError Specifies handling of values that cannot be converted
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
*/

@@ -35,3 +84,3 @@ convertOptional(from: unknown, onError?: OnError): Result<T | undefined>;

*
* @param onError Specifies handling of values that cannot be converted
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
* */

@@ -38,0 +87,0 @@ optional(onError?: OnError): Converter<T | undefined>;

36

converter.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Converter = void 0;
exports.BaseConverter = void 0;
/*

@@ -29,3 +29,3 @@ * Copyright (c) 2020 Erik Fortune

*/
class Converter {
class BaseConverter {
constructor(converter) {

@@ -40,3 +40,3 @@ this._converter = converter;

convert(from) {
return this._converter(from);
return this._converter(from, this);
}

@@ -51,7 +51,8 @@ /**

* @param from The unknown to be converted
* @param onError Specifies handling of values that cannot be converted
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
*/
convertOptional(from, onError = 'ignoreErrors') {
const result = this._converter(from);
convertOptional(from, onError) {
const result = this._converter(from, this);
if (result.isFailure()) {
onError = onError !== null && onError !== void 0 ? onError : 'ignoreErrors';
return ((from === undefined) || onError === 'ignoreErrors') ? result_1.succeed(undefined) : result;

@@ -69,6 +70,7 @@ }

*
* @param onError Specifies handling of values that cannot be converted
* @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'
* */
optional(onError = 'ignoreErrors') {
return new Converter((from) => {
optional(onError) {
return new BaseConverter((from) => {
onError = onError !== null && onError !== void 0 ? onError : 'ignoreErrors';
return this.convertOptional(from, onError);

@@ -82,4 +84,4 @@ });

map(mapper) {
return new Converter((from) => {
const innerResult = this._converter(from);
return new BaseConverter((from) => {
const innerResult = this._converter(from, this);
if (innerResult.isSuccess()) {

@@ -96,4 +98,4 @@ return mapper(innerResult.value);

mapConvert(mapConverter) {
return new Converter((from) => {
const innerResult = this._converter(from);
return new BaseConverter((from) => {
const innerResult = this._converter(from, this);
if (innerResult.isSuccess()) {

@@ -114,4 +116,4 @@ return mapConverter.convert(innerResult.value);

withConstraint(constraint) {
return new Converter((from) => {
const result = this._converter(from);
return new BaseConverter((from) => {
const result = this._converter(from, this);
if (result.isSuccess()) {

@@ -128,3 +130,3 @@ const constraintResult = constraint(result.value);

}
exports.Converter = Converter;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"converter.js","sourceRoot":"","sources":["../src/converter.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qCAAiD;AAIjD;;GAEG;AACH,MAAa,SAAS;IAGlB,YAAmB,SAAuC;QACtD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAa;QACxB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;;;;OASG;IACI,eAAe,CAAC,IAAa,EAAE,UAAmB,cAAc;QACnE,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,MAAM,CAAC,SAAS,EAAE,EAAE;YACpB,OAAO,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,OAAO,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC,gBAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;SAC7F;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;;;;;;;;SASK;IACE,QAAQ,CAAC,UAAmB,cAAc;QAC7C,OAAO,IAAI,SAAS,CAAC,CAAC,IAAa,EAAE,EAAE;YACnC,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACI,GAAG,CAAK,MAA+B;QAC1C,OAAO,IAAI,SAAS,CAAC,CAAC,IAAa,EAAE,EAAE;YACnC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC1C,IAAI,WAAW,CAAC,SAAS,EAAE,EAAE;gBACzB,OAAO,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aACpC;YACD,OAAO,aAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACI,UAAU,CAAK,YAA2B;QAC7C,OAAO,IAAI,SAAS,CAAC,CAAC,IAAa,EAAE,EAAE;YACnC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC1C,IAAI,WAAW,CAAC,SAAS,EAAE,EAAE;gBACzB,OAAO,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aAClD;YACD,OAAO,aAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;OAOG;IACI,cAAc,CAAC,UAAyC;QAC3D,OAAO,IAAI,SAAS,CAAC,CAAC,IAAa,EAAE,EAAE;YACnC,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACrC,IAAI,MAAM,CAAC,SAAS,EAAE,EAAE;gBACpB,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAClD,IAAI,OAAO,gBAAgB,KAAK,SAAS,EAAE;oBACvC,OAAO,gBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,aAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;iBAC9G;gBACD,OAAO,gBAAgB,CAAC;aAC3B;YACD,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AAnGD,8BAmGC","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nimport { Result, fail, succeed } from './result';\n\ntype OnError = 'failOnError' | 'ignoreErrors';\n\n/**\n * Simple templated converter wrapper to simplify typed conversion from unknown.\n */\nexport class Converter<T> {\n    private _converter: (from: unknown) => Result<T>;\n\n    public constructor(converter: (from: unknown) => Result<T>) {\n        this._converter = converter;\n    }\n\n    /**\n     * Converts from unknown to <T>\n     * @param from The unknown to be converted\n     * @returns An @see Result with a value or an error message\n     */\n    public convert(from: unknown): Result<T> {\n        return this._converter(from);\n    }\n\n    /**\n     * Converts from unknown to <T> or undefined, as appropriate.\n     * If 'onError' is 'failOnError', the converter succeeds for\n     * 'undefined' or any convertible value, but reports an error\n     * if it encounters a value that cannot be converted.  If 'onError'\n     * is 'ignoreErrors' (default) then values that cannot be converted\n     * result in a successful return of 'undefined'.\n     * @param from The unknown to be converted\n     * @param onError Specifies handling of values that cannot be converted\n     */\n    public convertOptional(from: unknown, onError: OnError = 'ignoreErrors'): Result<T|undefined> {\n        const result = this._converter(from);\n        if (result.isFailure()) {\n            return ((from === undefined) || onError === 'ignoreErrors') ? succeed(undefined) : result;\n        }\n        return result;\n    }\n\n    /**\n     * Creates a converter for an optional value. If 'onError'\n     * is 'failOnError', the converter accepts 'undefined' or a\n     * convertible value, but reports an error if it encounters\n     * a value that cannot be converted.  If 'onError' is 'ignoreErrors'\n     * (default) then values that cannot be converted result in a\n     * successful return of 'undefined'.\n     *\n     * @param onError Specifies handling of values that cannot be converted\n     * */\n    public optional(onError: OnError = 'ignoreErrors'): Converter<T|undefined> {\n        return new Converter((from: unknown) => {\n            return this.convertOptional(from, onError);\n        });\n    }\n\n    /**\n     * Applies a (possibly) mapping conversion to the converted value.\n     * @param mapper A function which maps from the converted type to some other type.\n     */\n    public map<T2>(mapper: (from: T) => Result<T2>): Converter<T2> {\n        return new Converter((from: unknown) => {\n            const innerResult = this._converter(from);\n            if (innerResult.isSuccess()) {\n                return mapper(innerResult.value);\n            }\n            return fail(innerResult.message);\n        });\n    }\n\n    /**\n     * Applies an additional converter to the converted value.\n     * @param mapConverter The converter to be applied to the converted value\n     */\n    public mapConvert<T2>(mapConverter: Converter<T2>): Converter<T2> {\n        return new Converter((from: unknown) => {\n            const innerResult = this._converter(from);\n            if (innerResult.isSuccess()) {\n                return mapConverter.convert(innerResult.value);\n            }\n            return fail(innerResult.message);\n        });\n    }\n\n    /**\n     * Creates a converter with an optional constraint.  If the base converter\n     * succeeds, calls a supplied constraint evaluation function with the\n     * value and fails the conversion if the function returns either false\n     * or Failure<T>.\n     *\n     * @param constraint Constraint evaluation function\n     */\n    public withConstraint(constraint: (val: T) => boolean|Result<T>): Converter<T> {\n        return new Converter((from: unknown) => {\n            const result = this._converter(from);\n            if (result.isSuccess()) {\n                const constraintResult = constraint(result.value);\n                if (typeof constraintResult === 'boolean') {\n                    return constraintResult ? result : fail(`Value ${JSON.stringify(result.value)} does not meet constraint.`);\n                }\n                return constraintResult;\n            }\n            return result;\n        });\n    }\n}\n"]}
exports.BaseConverter = BaseConverter;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"converter.js","sourceRoot":"","sources":["../src/converter.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qCAAiD;AA2DjD;;GAEG;AACH,MAAa,aAAa;IAGtB,YAAmB,SAA2D;QAC1E,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAa;QACxB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED;;;;;;;;;OASG;IACI,eAAe,CAAC,IAAa,EAAE,OAAiB;QACnD,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC3C,IAAI,MAAM,CAAC,SAAS,EAAE,EAAE;YACpB,OAAO,GAAG,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,cAAc,CAAC;YACpC,OAAO,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,OAAO,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC,gBAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;SAC7F;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;;;;;;;;SASK;IACE,QAAQ,CAAC,OAAiB;QAC7B,OAAO,IAAI,aAAa,CAAC,CAAC,IAAa,EAAE,EAAE;YACvC,OAAO,GAAG,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,cAAc,CAAC;YACpC,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACI,GAAG,CAAK,MAA+B;QAC1C,OAAO,IAAI,aAAa,CAAC,CAAC,IAAa,EAAE,EAAE;YACvC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAChD,IAAI,WAAW,CAAC,SAAS,EAAE,EAAE;gBACzB,OAAO,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aACpC;YACD,OAAO,aAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACI,UAAU,CAAK,YAA2B;QAC7C,OAAO,IAAI,aAAa,CAAC,CAAC,IAAa,EAAE,EAAE;YACvC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAChD,IAAI,WAAW,CAAC,SAAS,EAAE,EAAE;gBACzB,OAAO,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aAClD;YACD,OAAO,aAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;OAOG;IACI,cAAc,CAAC,UAAyC;QAC3D,OAAO,IAAI,aAAa,CAAC,CAAC,IAAa,EAAE,EAAE;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC3C,IAAI,MAAM,CAAC,SAAS,EAAE,EAAE;gBACpB,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAClD,IAAI,OAAO,gBAAgB,KAAK,SAAS,EAAE;oBACvC,OAAO,gBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,aAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;iBAC9G;gBACD,OAAO,gBAAgB,CAAC;aAC3B;YACD,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AArGD,sCAqGC","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nimport { Result, fail, succeed } from './result';\n\ntype OnError = 'failOnError' | 'ignoreErrors';\n\nexport interface Converter<T> {\n    /**\n     * Converts from unknown to <T>\n     * @param from The unknown to be converted\n     * @returns An @see Result with a value or an error message\n     */\n    convert(from: unknown): Result<T>;\n\n    /**\n     * Converts from unknown to <T> or undefined, as appropriate.\n     * If 'onError' is 'failOnError', the converter succeeds for\n     * 'undefined' or any convertible value, but reports an error\n     * if it encounters a value that cannot be converted.  If 'onError'\n     * is 'ignoreErrors' (default) then values that cannot be converted\n     * result in a successful return of 'undefined'.\n     * @param from The unknown to be converted\n     * @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'\n     */\n    convertOptional(from: unknown, onError?: OnError): Result<T|undefined>;\n\n    /**\n     * Creates a converter for an optional value. If 'onError'\n     * is 'failOnError', the converter accepts 'undefined' or a\n     * convertible value, but reports an error if it encounters\n     * a value that cannot be converted.  If 'onError' is 'ignoreErrors'\n     * (default) then values that cannot be converted result in a\n     * successful return of 'undefined'.\n     *\n     * @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'\n     * */\n    optional(onError?: OnError): Converter<T|undefined>;\n\n    /**\n     * Applies a (possibly) mapping conversion to the converted value.\n     * @param mapper A function which maps from the converted type to some other type.\n     */\n    map<T2>(mapper: (from: T) => Result<T2>): Converter<T2>;\n\n    /**\n     * Applies an additional converter to the converted value.\n     * @param mapConverter The converter to be applied to the converted value\n     */\n    mapConvert<T2>(mapConverter: Converter<T2>): Converter<T2>;\n\n    /**\n     * Creates a converter with an optional constraint.  If the base converter\n     * succeeds, calls a supplied constraint evaluation function with the\n     * value and fails the conversion if the function returns either false\n     * or Failure<T>.\n     *\n     * @param constraint Constraint evaluation function\n     */\n    withConstraint(constraint: (val: T) => boolean|Result<T>): Converter<T>;\n}\n\n/**\n * Simple templated converter wrapper to simplify typed conversion from unknown.\n */\nexport class BaseConverter<T> implements Converter<T> {\n    private _converter: (from: unknown, self: Converter<T>) => Result<T>;\n\n    public constructor(converter: (from: unknown, self: Converter<T>) => Result<T>) {\n        this._converter = converter;\n    }\n\n    /**\n     * Converts from unknown to <T>\n     * @param from The unknown to be converted\n     * @returns An @see Result with a value or an error message\n     */\n    public convert(from: unknown): Result<T> {\n        return this._converter(from, this);\n    }\n\n    /**\n     * Converts from unknown to <T> or undefined, as appropriate.\n     * If 'onError' is 'failOnError', the converter succeeds for\n     * 'undefined' or any convertible value, but reports an error\n     * if it encounters a value that cannot be converted.  If 'onError'\n     * is 'ignoreErrors' (default) then values that cannot be converted\n     * result in a successful return of 'undefined'.\n     * @param from The unknown to be converted\n     * @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'\n     */\n    public convertOptional(from: unknown, onError?: OnError): Result<T|undefined> {\n        const result = this._converter(from, this);\n        if (result.isFailure()) {\n            onError = onError ?? 'ignoreErrors';\n            return ((from === undefined) || onError === 'ignoreErrors') ? succeed(undefined) : result;\n        }\n        return result;\n    }\n\n    /**\n     * Creates a converter for an optional value. If 'onError'\n     * is 'failOnError', the converter accepts 'undefined' or a\n     * convertible value, but reports an error if it encounters\n     * a value that cannot be converted.  If 'onError' is 'ignoreErrors'\n     * (default) then values that cannot be converted result in a\n     * successful return of 'undefined'.\n     *\n     * @param onError Specifies handling of values that cannot be converted, default 'ignoreErrors'\n     * */\n    public optional(onError?: OnError): Converter<T|undefined> {\n        return new BaseConverter((from: unknown) => {\n            onError = onError ?? 'ignoreErrors';\n            return this.convertOptional(from, onError);\n        });\n    }\n\n    /**\n     * Applies a (possibly) mapping conversion to the converted value.\n     * @param mapper A function which maps from the converted type to some other type.\n     */\n    public map<T2>(mapper: (from: T) => Result<T2>): Converter<T2> {\n        return new BaseConverter((from: unknown) => {\n            const innerResult = this._converter(from, this);\n            if (innerResult.isSuccess()) {\n                return mapper(innerResult.value);\n            }\n            return fail(innerResult.message);\n        });\n    }\n\n    /**\n     * Applies an additional converter to the converted value.\n     * @param mapConverter The converter to be applied to the converted value\n     */\n    public mapConvert<T2>(mapConverter: Converter<T2>): Converter<T2> {\n        return new BaseConverter((from: unknown) => {\n            const innerResult = this._converter(from, this);\n            if (innerResult.isSuccess()) {\n                return mapConverter.convert(innerResult.value);\n            }\n            return fail(innerResult.message);\n        });\n    }\n\n    /**\n     * Creates a converter with an optional constraint.  If the base converter\n     * succeeds, calls a supplied constraint evaluation function with the\n     * value and fails the conversion if the function returns either false\n     * or Failure<T>.\n     *\n     * @param constraint Constraint evaluation function\n     */\n    public withConstraint(constraint: (val: T) => boolean|Result<T>): Converter<T> {\n        return new BaseConverter((from: unknown) => {\n            const result = this._converter(from, this);\n            if (result.isSuccess()) {\n                const constraintResult = constraint(result.value);\n                if (typeof constraintResult === 'boolean') {\n                    return constraintResult ? result : fail(`Value ${JSON.stringify(result.value)} does not meet constraint.`);\n                }\n                return constraintResult;\n            }\n            return result;\n        });\n    }\n}\n"]}

@@ -0,4 +1,4 @@

import { BaseConverter, Converter } from './converter';
import { RangeOf, RangeOfProperties } from './rangeOf';
import { Result } from './result';
import { Converter } from './converter';
import { ExtendedArray } from './extendedArray';

@@ -10,3 +10,3 @@ declare type OnError = 'failOnError' | 'ignoreErrors';

*/
export declare const string: Converter<string>;
export declare const string: BaseConverter<string>;
/**

@@ -22,3 +22,3 @@ *

*/
export declare const number: Converter<number>;
export declare const number: BaseConverter<number>;
/**

@@ -29,3 +29,3 @@ * A converter to convert unknown to boolean. Boolean values or the

*/
export declare const boolean: Converter<boolean>;
export declare const boolean: BaseConverter<boolean>;
/**

@@ -112,3 +112,3 @@ * A converter to convert an optional string value. Values of type string

};
export declare class ObjectConverter<T> extends Converter<T> {
export declare class ObjectConverter<T> extends BaseConverter<T> {
readonly fields: FieldConverters<T>;

@@ -115,0 +115,0 @@ readonly optionalFields: (keyof T)[];

@@ -25,5 +25,5 @@ "use strict";

*/
const converter_1 = require("./converter");
const rangeOf_1 = require("./rangeOf");
const result_1 = require("./result");
const converter_1 = require("./converter");
const extendedArray_1 = require("./extendedArray");

@@ -35,3 +35,3 @@ const utils_1 = require("./utils");

*/
exports.string = new converter_1.Converter((from) => {
exports.string = new converter_1.BaseConverter((from) => {
return typeof from === 'string'

@@ -47,3 +47,3 @@ ? result_1.succeed(from)

function enumeratedValue(values) {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
const index = values.indexOf(from);

@@ -58,3 +58,3 @@ return (index >= 0 ? result_1.succeed(values[index]) : result_1.fail(`Invalid enumerated value ${JSON.stringify(from)}`));

*/
exports.number = new converter_1.Converter((from) => {
exports.number = new converter_1.BaseConverter((from) => {
if (typeof from !== 'number') {

@@ -73,3 +73,3 @@ const num = (typeof from === 'string' ? Number(from) : NaN);

*/
exports.boolean = new converter_1.Converter((from) => {
exports.boolean = new converter_1.BaseConverter((from) => {
if (typeof from === 'boolean') {

@@ -97,3 +97,3 @@ return result_1.succeed(from);

function delimitedString(delimiter, options = 'filtered') {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
const result = exports.string.convert(from);

@@ -137,3 +137,3 @@ if (result.isSuccess()) {

function oneOf(converters, onError = 'ignoreErrors') {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
const errors = [];

@@ -164,3 +164,3 @@ for (const converter of converters) {

function arrayOf(converter, onError = 'failOnError') {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
if (!Array.isArray(from)) {

@@ -207,3 +207,3 @@ return result_1.fail(`Not an array: ${JSON.stringify(from)}`);

function recordOf(converter, onError = 'fail') {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
if ((typeof from !== 'object') || Array.isArray(from)) {

@@ -239,3 +239,3 @@ return result_1.fail(`Not a string-keyed object: ${JSON.stringify(from)}`);

function field(name, converter) {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
if (typeof from === 'object' && from !== null) {

@@ -262,3 +262,3 @@ if (utils_1.isKeyOf(name, from)) {

function optionalField(name, converter) {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
if (typeof from === 'object' && from !== null) {

@@ -282,3 +282,3 @@ if (utils_1.isKeyOf(name, from)) {

exports.optionalField = optionalField;
class ObjectConverter extends converter_1.Converter {
class ObjectConverter extends converter_1.BaseConverter {
constructor(fields, optional) {

@@ -347,3 +347,3 @@ super((from) => {

function transform(fields) {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
const converted = {};

@@ -372,3 +372,3 @@ const errors = [];

function rangeTypeOf(converter, constructor) {
return new converter_1.Converter((from) => {
return new converter_1.BaseConverter((from) => {
const result = object({

@@ -389,2 +389,2 @@ min: converter,

exports.rangeOf = rangeOf;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"converters.js","sourceRoot":"","sources":["../src/converters.ts"],"names":[],"mappings":"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","sourcesContent":["\n/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nimport { RangeOf, RangeOfProperties } from './rangeOf';\nimport { Result, captureResult, fail, succeed } from './result';\nimport { Converter } from './converter';\nimport { ExtendedArray } from './extendedArray';\nimport { isKeyOf } from './utils';\n\ntype OnError = 'failOnError' | 'ignoreErrors';\n\n/**\n * A converter to convert unknown to string. Values of type\n * string succeed.  Anything else fails.\n */\nexport const string = new Converter<string>((from: unknown) => {\n    return typeof from === 'string'\n        ? succeed(from as string)\n        : fail(`Not a string: ${JSON.stringify(from)}`);\n});\n\n/**\n *\n * @param values A converter to convert unknown to one of a set of\n * supplied enumerated values.  Anything else fails.\n */\nexport function enumeratedValue<T>(values: T[]): Converter<T> {\n    return new Converter<T>((from: unknown): Result<T> => {\n        const index = values.indexOf(from as T);\n        return (index >= 0 ? succeed(values[index]) : fail(`Invalid enumerated value ${JSON.stringify(from)}`));\n    });\n}\n\n/**\n * A converter to convert unknown to a number.  Numbers and strings\n * with a numeric format succeed.  Anything else fails.\n */\nexport const number = new Converter<number>((from: unknown) => {\n    if (typeof from !== 'number') {\n        const num: number = (typeof from === 'string' ? Number(from) : NaN);\n        return isNaN(num)\n            ? fail(`Not a number: ${JSON.stringify(from)}`)\n            : succeed(num);\n    }\n    return succeed(from);\n});\n\n/**\n * A converter to convert unknown to boolean. Boolean values or the\n * case-insensitive strings 'true' and 'false' succeed.  Anything\n * else fails.\n */\nexport const boolean = new Converter<boolean>((from: unknown) => {\n    if (typeof from === 'boolean') {\n        return succeed(from as boolean);\n    }\n    else if (typeof from === 'string') {\n        switch (from.toLowerCase()) {\n            case 'true': return succeed(true);\n            case 'false': return succeed(false);\n        }\n    }\n    return fail(`Not a boolean: ${JSON.stringify(from)}`);\n});\n\n/**\n * A converter to convert an optional string value. Values of type string\n * are returned.  Anything else returns success with an undefined value.\n */\nexport const optionalString = string.optional();\n\n/**\n * Creates a converter which converts any string into an array of strings\n * by separating at a supplied delimiter.\n * @param delimiter The delimiter at which to split.\n */\nexport function delimitedString(delimiter: string, options: 'filtered'|'all' = 'filtered'): Converter<string[]> {\n    return new Converter<string[]>((from: unknown) => {\n        const result = string.convert(from);\n        if (result.isSuccess()) {\n            let strings = result.value.split(delimiter);\n            if (options !== 'all') {\n                strings = strings.filter((s) => (s.trim().length > 0));\n            }\n            return succeed(strings);\n        }\n        return fail(result.message);\n    });\n}\n\n/**\n * A converter to convert an optional number value. Values of type number\n * or numeric strings are converted and returned. Anything else returns\n * success with an undefined value.\n */\nexport const optionalNumber = number.optional();\n\n/**\n * A converter to convert an optional boolean value. Values of type boolean\n * or strings that match (case-insensitive) 'true' or 'false' are converted\n * and returned.  Anything else returns success with an undefined value.\n */\nexport const optionalBoolean = boolean.optional();\n\n/**\n * A helper wrapper for polymorphic fields. Invokes the wrapped converters\n * in sequence, returning the first successful result.  Returns an error\n * if none of the supplied converters can convert the value.\n *\n * If onError is 'ignoreErrors' (default), then errors from any of the\n * converters are ignored provided that some converter succeeds.  If\n * onError is 'failOnError', then an error from any converter fails the entire\n * conversion.\n *\n * @param converters An ordered list of converters to be considered\n * @param onError Specifies treatment of unconvertable elements\n */\nexport function oneOf<T>(converters: Array<Converter<T>>, onError: OnError = 'ignoreErrors'): Converter<T> {\n    return new Converter((from: unknown) => {\n        const errors: string[] = [];\n        for (const converter of converters) {\n            const result = converter.convert(from);\n            if (result.isSuccess() && (result.value !== undefined)) {\n                return result;\n            }\n\n            if (result.isFailure()) {\n                if (onError === 'failOnError') {\n                    return result;\n                }\n                errors.push(result.message);\n            }\n        }\n        return fail(`No matching converter for ${JSON.stringify(from)}: ${errors.join('\\n')}`);\n    });\n}\n\n/**\n * A helper wrapper for converting an array of <T>.  If onError is 'failOnError' (default),\n * then the entire conversion fails if any element cannot be converted.  If onError\n * is 'ignoreErrors', failing elements are silently ignored.\n * @param converter Converter used to convert each item in the array\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function arrayOf<T>(converter: Converter<T>, onError: OnError = 'failOnError'): Converter<T[]> {\n    return new Converter((from: unknown) => {\n        if (!Array.isArray(from)) {\n            return fail(`Not an array: ${JSON.stringify(from)}`);\n        }\n\n        const successes: T[] = [];\n        const errors: string[] = [];\n        for (const item of from) {\n            const result = converter.convert(item);\n            if (result.isSuccess() && result.value !== undefined) {\n                successes.push(result.value);\n            }\n            else if (result.isFailure()) {\n                errors.push(result.message);\n            }\n        }\n\n        return (errors.length === 0) || (onError === 'ignoreErrors')\n            ? succeed(successes)\n            : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper wrapper for converting to Itemrray<T>.  If onError is 'failOnError' (default),\n * then the entire conversion fails if any element cannot be converted.  If onError\n * is 'ignoreErrors', failing elements are silently ignored.\n * @param converter Converter used to convert each item in the array\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function extendedArrayOf<T>(label: string, converter: Converter<T>, onError: OnError = 'failOnError'): Converter<ExtendedArray<T>> {\n    return arrayOf(converter, onError).map((items: T[]) => {\n        return captureResult(() => new ExtendedArray(label, ...items));\n    });\n}\n\n/**\n * A helper wrapper to convert the string-keyed properties of an object to a Record of T.\n * If onError is 'fail' (default),  then the entire conversion fails if any element\n * cannot be converted.  If onError is 'ignore' failing elements are silently ignored.\n * @param converter Converter used to convert each item in the record\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function recordOf<T>(converter: Converter<T>, onError: 'fail'|'ignore' = 'fail'): Converter<Record<string, T>> {\n    return new Converter((from: unknown) => {\n        if ((typeof from !== 'object') || Array.isArray(from)) {\n            return fail(`Not a string-keyed object: ${JSON.stringify(from)}`);\n        }\n\n        const record: Record<string, T> = {};\n        const errors: string[] = [];\n\n        for (const key in from) {\n            if (isKeyOf(key, from)) {\n                const result = converter.convert(from[key] as unknown);\n                if (result.isSuccess()) {\n                    record[key] = result.value;\n                }\n                else {\n                    errors.push(result.message);\n                }\n            }\n        }\n\n        return (errors.length === 0) || (onError === 'ignore')\n            ? succeed(record)\n            : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper function to extract and convert a field from an object. Succeeds and returns\n * the converted value if the field exists in the supplied parameter and can be converted.\n * Fails otherwise.\n * @param name The name of the field to be extracted.\n * @param converter Converter used to convert the extracted field.\n */\nexport function field<T>(name: string, converter: Converter<T>): Converter<T> {\n    return new Converter((from: unknown) => {\n        if (typeof from === 'object' && from !== null) {\n            if (isKeyOf(name, from)) {\n                return converter.convert(from[name]).onFailure((message) => {\n                    return fail(`Field ${name}: ${message}`);\n                });\n            }\n            return fail(`Field ${name} not found in: ${JSON.stringify(from)}`);\n        }\n        return fail(`Cannot convert field \"${name}\" from non-object ${JSON.stringify(from)}`);\n    });\n}\n\n/**\n * A helper function to extract and convert an optional field from an object. Succeeds\n * and returns the converted value if the field exists in the supplied parameter and can\n * be converted. Succeeds with undefined if the parameter is an object but the named field\n * is not present. Fails if the supplied parameter is not an object.\n * @param name The name of the field to be extracted.\n * @param converter Converter used to convert the extracted field.\n */\nexport function optionalField<T>(name: string, converter: Converter<T>): Converter<T|undefined> {\n    return new Converter((from: unknown) => {\n        if (typeof from === 'object' && from !== null) {\n            if (isKeyOf(name, from)) {\n                const result = converter.convert(from[name]).onFailure((message) => {\n                    return fail(`${name}: ${message}`);\n                });\n\n                // if conversion was successful or input was undefined we\n                // succeed with 'undefined', but we propagate actual\n                // failures.\n                if (result.isSuccess() || (from[name] !== undefined)) {\n                    return result;\n                }\n            }\n            return succeed(undefined);\n        }\n        return fail(`Cannot convert field \"${name}\" from non-object ${JSON.stringify(from)}`);\n    });\n}\n\nexport type FieldConverters<T> = { [ key in keyof T ]: Converter<T[key]> };\n\nexport class ObjectConverter<T> extends Converter<T> {\n    public readonly fields: FieldConverters<T>;\n    public readonly optionalFields: (keyof T)[];\n\n    public constructor(fields: FieldConverters<T>, optional?: (keyof T)[]) {\n        super((from: unknown) => {\n            const converted = {} as { [key in keyof T]: T[key] };\n            const errors: string[] = [];\n            for (const key in fields) {\n                if (fields[key]) {\n                    const isOptional = optional?.includes(key) ?? false;\n                    const result = isOptional\n                        ? optionalField(key, fields[key]).convert(from)\n                        : field(key, fields[key]).convert(from);\n                    if (result.isSuccess() && (result.value !== undefined)) {\n                        converted[key] = result.value;\n                    }\n                    else if (result.isFailure()) {\n                        errors.push(result.message);\n                    }\n                }\n            }\n            return (errors.length === 0) ? succeed(converted) : fail(errors.join('\\n'));\n        });\n\n        this.fields = fields;\n        this.optionalFields = optional ?? [];\n    }\n\n    public partial(optional?: (keyof T)[]): ObjectConverter<Partial<T>> {\n        return new ObjectConverter(this.fields, optional);\n    }\n\n    public addPartial(addOptionalFields: (keyof T)[]): ObjectConverter<Partial<T>> {\n        return this.partial([...this.optionalFields, ...addOptionalFields]);\n    }\n}\n\n/**\n * Helper to convert an object without changing shape. The source parameter is an object with\n * key names that correspond to the target object and the appropriate corresponding converter\n * as the property value. If all of the requested fields exist and can be converted, returns a\n * new object with the converted values under the original key names.  If any fields do not exist\n * or cannot be converted, the entire conversion fails.\n *\n * Fields that succeed but convert to undefined are omitted from the result object but do not\n * fail the conversion.\n * @param fields An object containing defining the shape and converters to be applied.\n */\nexport function object<T>(fields: FieldConverters<T>, optional?: (keyof T)[]): ObjectConverter<T> {\n    return new ObjectConverter(fields, optional);\n}\n\n/**\n * Helper to convert an object to a new object with a different shape. The source parameter is\n * an object with key names that correspond to the target object, and an approriate _field_\n * converter that will extract and convert a single field from the source object.\n *\n * If all of the extracted fields exist and can be converted, returns a new object with the\n * converted values under the original key names.  If any fields to be extracted do not exist\n * or cannot be converted, the entire conversion fails.\n *\n * Fields that succeed but convert to undefined are omitted from the result object but do not\n * fail the conversion.\n *\n * @param fields An object defining the shape of the target object and the field converters\n * to be used to construct it.\n */\nexport function transform<T>(fields: FieldConverters<T>): Converter<T> {\n    return new Converter((from: unknown) => {\n        const converted = {} as { [ key in keyof T]: T[key] };\n        const errors: string[] = [];\n\n        for (const key in fields) {\n            if (fields[key]) {\n                const result = fields[key].convert(from);\n                if (result.isSuccess() && (result.value !== undefined)) {\n                    converted[key] = result.value;\n                }\n                else if (result.isFailure()) {\n                    errors.push(result.message);\n                }\n            }\n        }\n\n        return (errors.length === 0) ? succeed(converted) : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper wrapper to convert a range of some other comparable type\n * @param converter Converter used to convert min and max extent of the raid\n * @param constructor Optional static constructor to instantiate the object\n */\nexport function rangeTypeOf<T, RT extends RangeOf<T>>(converter: Converter<T>, constructor: (init: RangeOfProperties<T>) => Result<RT>): Converter<RT> {\n    return new Converter((from: unknown) => {\n        const result = object({\n            min: converter,\n            max: converter,\n        }, ['min', 'max']).convert(from);\n        if (result.isSuccess()) {\n            return constructor({ min: result.value.min, max: result.value.max });\n        }\n        return fail(result.message);\n    });\n}\n\nexport function rangeOf<T>(converter: Converter<T>): Converter<RangeOf<T>> {\n    return rangeTypeOf<T, RangeOf<T>>(converter, RangeOf.createRange);\n}\n\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"converters.js","sourceRoot":"","sources":["../src/converters.ts"],"names":[],"mappings":"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","sourcesContent":["\n/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nimport { BaseConverter, Converter } from './converter';\nimport { RangeOf, RangeOfProperties } from './rangeOf';\nimport { Result, captureResult, fail, succeed } from './result';\nimport { ExtendedArray } from './extendedArray';\nimport { isKeyOf } from './utils';\n\ntype OnError = 'failOnError' | 'ignoreErrors';\n\n/**\n * A converter to convert unknown to string. Values of type\n * string succeed.  Anything else fails.\n */\nexport const string = new BaseConverter<string>((from: unknown) => {\n    return typeof from === 'string'\n        ? succeed(from as string)\n        : fail(`Not a string: ${JSON.stringify(from)}`);\n});\n\n/**\n *\n * @param values A converter to convert unknown to one of a set of\n * supplied enumerated values.  Anything else fails.\n */\nexport function enumeratedValue<T>(values: T[]): Converter<T> {\n    return new BaseConverter<T>((from: unknown): Result<T> => {\n        const index = values.indexOf(from as T);\n        return (index >= 0 ? succeed(values[index]) : fail(`Invalid enumerated value ${JSON.stringify(from)}`));\n    });\n}\n\n/**\n * A converter to convert unknown to a number.  Numbers and strings\n * with a numeric format succeed.  Anything else fails.\n */\nexport const number = new BaseConverter<number>((from: unknown) => {\n    if (typeof from !== 'number') {\n        const num: number = (typeof from === 'string' ? Number(from) : NaN);\n        return isNaN(num)\n            ? fail(`Not a number: ${JSON.stringify(from)}`)\n            : succeed(num);\n    }\n    return succeed(from);\n});\n\n/**\n * A converter to convert unknown to boolean. Boolean values or the\n * case-insensitive strings 'true' and 'false' succeed.  Anything\n * else fails.\n */\nexport const boolean = new BaseConverter<boolean>((from: unknown) => {\n    if (typeof from === 'boolean') {\n        return succeed(from as boolean);\n    }\n    else if (typeof from === 'string') {\n        switch (from.toLowerCase()) {\n            case 'true': return succeed(true);\n            case 'false': return succeed(false);\n        }\n    }\n    return fail(`Not a boolean: ${JSON.stringify(from)}`);\n});\n\n/**\n * A converter to convert an optional string value. Values of type string\n * are returned.  Anything else returns success with an undefined value.\n */\nexport const optionalString = string.optional();\n\n/**\n * Creates a converter which converts any string into an array of strings\n * by separating at a supplied delimiter.\n * @param delimiter The delimiter at which to split.\n */\nexport function delimitedString(delimiter: string, options: 'filtered'|'all' = 'filtered'): Converter<string[]> {\n    return new BaseConverter<string[]>((from: unknown) => {\n        const result = string.convert(from);\n        if (result.isSuccess()) {\n            let strings = result.value.split(delimiter);\n            if (options !== 'all') {\n                strings = strings.filter((s) => (s.trim().length > 0));\n            }\n            return succeed(strings);\n        }\n        return fail(result.message);\n    });\n}\n\n/**\n * A converter to convert an optional number value. Values of type number\n * or numeric strings are converted and returned. Anything else returns\n * success with an undefined value.\n */\nexport const optionalNumber = number.optional();\n\n/**\n * A converter to convert an optional boolean value. Values of type boolean\n * or strings that match (case-insensitive) 'true' or 'false' are converted\n * and returned.  Anything else returns success with an undefined value.\n */\nexport const optionalBoolean = boolean.optional();\n\n/**\n * A helper wrapper for polymorphic fields. Invokes the wrapped converters\n * in sequence, returning the first successful result.  Returns an error\n * if none of the supplied converters can convert the value.\n *\n * If onError is 'ignoreErrors' (default), then errors from any of the\n * converters are ignored provided that some converter succeeds.  If\n * onError is 'failOnError', then an error from any converter fails the entire\n * conversion.\n *\n * @param converters An ordered list of converters to be considered\n * @param onError Specifies treatment of unconvertable elements\n */\nexport function oneOf<T>(converters: Array<Converter<T>>, onError: OnError = 'ignoreErrors'): Converter<T> {\n    return new BaseConverter((from: unknown) => {\n        const errors: string[] = [];\n        for (const converter of converters) {\n            const result = converter.convert(from);\n            if (result.isSuccess() && (result.value !== undefined)) {\n                return result;\n            }\n\n            if (result.isFailure()) {\n                if (onError === 'failOnError') {\n                    return result;\n                }\n                errors.push(result.message);\n            }\n        }\n        return fail(`No matching converter for ${JSON.stringify(from)}: ${errors.join('\\n')}`);\n    });\n}\n\n/**\n * A helper wrapper for converting an array of <T>.  If onError is 'failOnError' (default),\n * then the entire conversion fails if any element cannot be converted.  If onError\n * is 'ignoreErrors', failing elements are silently ignored.\n * @param converter Converter used to convert each item in the array\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function arrayOf<T>(converter: Converter<T>, onError: OnError = 'failOnError'): Converter<T[]> {\n    return new BaseConverter((from: unknown) => {\n        if (!Array.isArray(from)) {\n            return fail(`Not an array: ${JSON.stringify(from)}`);\n        }\n\n        const successes: T[] = [];\n        const errors: string[] = [];\n        for (const item of from) {\n            const result = converter.convert(item);\n            if (result.isSuccess() && result.value !== undefined) {\n                successes.push(result.value);\n            }\n            else if (result.isFailure()) {\n                errors.push(result.message);\n            }\n        }\n\n        return (errors.length === 0) || (onError === 'ignoreErrors')\n            ? succeed(successes)\n            : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper wrapper for converting to Itemrray<T>.  If onError is 'failOnError' (default),\n * then the entire conversion fails if any element cannot be converted.  If onError\n * is 'ignoreErrors', failing elements are silently ignored.\n * @param converter Converter used to convert each item in the array\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function extendedArrayOf<T>(label: string, converter: Converter<T>, onError: OnError = 'failOnError'): Converter<ExtendedArray<T>> {\n    return arrayOf(converter, onError).map((items: T[]) => {\n        return captureResult(() => new ExtendedArray(label, ...items));\n    });\n}\n\n/**\n * A helper wrapper to convert the string-keyed properties of an object to a Record of T.\n * If onError is 'fail' (default),  then the entire conversion fails if any element\n * cannot be converted.  If onError is 'ignore' failing elements are silently ignored.\n * @param converter Converter used to convert each item in the record\n * @param ignoreErrors Specifies treatment of unconvertable elements\n */\nexport function recordOf<T>(converter: Converter<T>, onError: 'fail'|'ignore' = 'fail'): Converter<Record<string, T>> {\n    return new BaseConverter((from: unknown) => {\n        if ((typeof from !== 'object') || Array.isArray(from)) {\n            return fail(`Not a string-keyed object: ${JSON.stringify(from)}`);\n        }\n\n        const record: Record<string, T> = {};\n        const errors: string[] = [];\n\n        for (const key in from) {\n            if (isKeyOf(key, from)) {\n                const result = converter.convert(from[key] as unknown);\n                if (result.isSuccess()) {\n                    record[key] = result.value;\n                }\n                else {\n                    errors.push(result.message);\n                }\n            }\n        }\n\n        return (errors.length === 0) || (onError === 'ignore')\n            ? succeed(record)\n            : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper function to extract and convert a field from an object. Succeeds and returns\n * the converted value if the field exists in the supplied parameter and can be converted.\n * Fails otherwise.\n * @param name The name of the field to be extracted.\n * @param converter Converter used to convert the extracted field.\n */\nexport function field<T>(name: string, converter: Converter<T>): Converter<T> {\n    return new BaseConverter((from: unknown) => {\n        if (typeof from === 'object' && from !== null) {\n            if (isKeyOf(name, from)) {\n                return converter.convert(from[name]).onFailure((message) => {\n                    return fail(`Field ${name}: ${message}`);\n                });\n            }\n            return fail(`Field ${name} not found in: ${JSON.stringify(from)}`);\n        }\n        return fail(`Cannot convert field \"${name}\" from non-object ${JSON.stringify(from)}`);\n    });\n}\n\n/**\n * A helper function to extract and convert an optional field from an object. Succeeds\n * and returns the converted value if the field exists in the supplied parameter and can\n * be converted. Succeeds with undefined if the parameter is an object but the named field\n * is not present. Fails if the supplied parameter is not an object.\n * @param name The name of the field to be extracted.\n * @param converter Converter used to convert the extracted field.\n */\nexport function optionalField<T>(name: string, converter: Converter<T>): Converter<T|undefined> {\n    return new BaseConverter((from: unknown) => {\n        if (typeof from === 'object' && from !== null) {\n            if (isKeyOf(name, from)) {\n                const result = converter.convert(from[name]).onFailure((message) => {\n                    return fail(`${name}: ${message}`);\n                });\n\n                // if conversion was successful or input was undefined we\n                // succeed with 'undefined', but we propagate actual\n                // failures.\n                if (result.isSuccess() || (from[name] !== undefined)) {\n                    return result;\n                }\n            }\n            return succeed(undefined);\n        }\n        return fail(`Cannot convert field \"${name}\" from non-object ${JSON.stringify(from)}`);\n    });\n}\n\nexport type FieldConverters<T> = { [ key in keyof T ]: Converter<T[key]> };\n\nexport class ObjectConverter<T> extends BaseConverter<T> {\n    public readonly fields: FieldConverters<T>;\n    public readonly optionalFields: (keyof T)[];\n\n    public constructor(fields: FieldConverters<T>, optional?: (keyof T)[]) {\n        super((from: unknown) => {\n            const converted = {} as { [key in keyof T]: T[key] };\n            const errors: string[] = [];\n            for (const key in fields) {\n                if (fields[key]) {\n                    const isOptional = optional?.includes(key) ?? false;\n                    const result = isOptional\n                        ? optionalField(key, fields[key]).convert(from)\n                        : field(key, fields[key]).convert(from);\n                    if (result.isSuccess() && (result.value !== undefined)) {\n                        converted[key] = result.value;\n                    }\n                    else if (result.isFailure()) {\n                        errors.push(result.message);\n                    }\n                }\n            }\n            return (errors.length === 0) ? succeed(converted) : fail(errors.join('\\n'));\n        });\n\n        this.fields = fields;\n        this.optionalFields = optional ?? [];\n    }\n\n    public partial(optional?: (keyof T)[]): ObjectConverter<Partial<T>> {\n        return new ObjectConverter<Partial<T>>(this.fields as FieldConverters<Partial<T>>, optional);\n    }\n\n    public addPartial(addOptionalFields: (keyof T)[]): ObjectConverter<Partial<T>> {\n        return this.partial([...this.optionalFields, ...addOptionalFields]);\n    }\n}\n\n/**\n * Helper to convert an object without changing shape. The source parameter is an object with\n * key names that correspond to the target object and the appropriate corresponding converter\n * as the property value. If all of the requested fields exist and can be converted, returns a\n * new object with the converted values under the original key names.  If any fields do not exist\n * or cannot be converted, the entire conversion fails.\n *\n * Fields that succeed but convert to undefined are omitted from the result object but do not\n * fail the conversion.\n * @param fields An object containing defining the shape and converters to be applied.\n */\nexport function object<T>(fields: FieldConverters<T>, optional?: (keyof T)[]): ObjectConverter<T> {\n    return new ObjectConverter(fields, optional);\n}\n\n/**\n * Helper to convert an object to a new object with a different shape. The source parameter is\n * an object with key names that correspond to the target object, and an approriate _field_\n * converter that will extract and convert a single field from the source object.\n *\n * If all of the extracted fields exist and can be converted, returns a new object with the\n * converted values under the original key names.  If any fields to be extracted do not exist\n * or cannot be converted, the entire conversion fails.\n *\n * Fields that succeed but convert to undefined are omitted from the result object but do not\n * fail the conversion.\n *\n * @param fields An object defining the shape of the target object and the field converters\n * to be used to construct it.\n */\nexport function transform<T>(fields: FieldConverters<T>): Converter<T> {\n    return new BaseConverter((from: unknown) => {\n        const converted = {} as { [ key in keyof T]: T[key] };\n        const errors: string[] = [];\n\n        for (const key in fields) {\n            if (fields[key]) {\n                const result = fields[key].convert(from);\n                if (result.isSuccess() && (result.value !== undefined)) {\n                    converted[key] = result.value;\n                }\n                else if (result.isFailure()) {\n                    errors.push(result.message);\n                }\n            }\n        }\n\n        return (errors.length === 0) ? succeed(converted) : fail(errors.join('\\n'));\n    });\n}\n\n/**\n * A helper wrapper to convert a range of some other comparable type\n * @param converter Converter used to convert min and max extent of the raid\n * @param constructor Optional static constructor to instantiate the object\n */\nexport function rangeTypeOf<T, RT extends RangeOf<T>>(converter: Converter<T>, constructor: (init: RangeOfProperties<T>) => Result<RT>): Converter<RT> {\n    return new BaseConverter((from: unknown) => {\n        const result = object({\n            min: converter,\n            max: converter,\n        }, ['min', 'max']).convert(from);\n        if (result.isSuccess()) {\n            return constructor({ min: result.value.min, max: result.value.max });\n        }\n        return fail(result.message);\n    });\n}\n\nexport function rangeOf<T>(converter: Converter<T>): Converter<RangeOf<T>> {\n    return rangeTypeOf<T, RangeOf<T>>(converter, RangeOf.createRange);\n}\n"]}

@@ -0,1 +1,2 @@

import { Converter } from './converter';
import { Result } from './result';

@@ -11,1 +12,3 @@ export declare type JsonPrimitive = boolean | number | string | null | undefined;

export declare function writeJsonFileSync(srcPath: string, value: JsonValue): Result<boolean>;
export declare function templatedJsonConverter(view?: unknown): Converter<JsonValue>;
export declare const jsonConverter: Converter<JsonValue>;

@@ -42,7 +42,13 @@ "use strict";

};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.writeJsonFileSync = exports.readJsonFileSync = void 0;
exports.jsonConverter = exports.templatedJsonConverter = exports.writeJsonFileSync = exports.readJsonFileSync = void 0;
const fs = __importStar(require("fs"));
const path = __importStar(require("path"));
const converter_1 = require("./converter");
const result_1 = require("./result");
const mustache_1 = __importDefault(require("mustache"));
const converters_1 = require("./converters");
function readJsonFileSync(srcPath) {

@@ -64,2 +70,38 @@ return result_1.captureResult(() => {

exports.writeJsonFileSync = writeJsonFileSync;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNvbkhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvanNvbkhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVILHVDQUF5QjtBQUN6QiwyQ0FBNkI7QUFDN0IscUNBQWlEO0FBUWpELFNBQWdCLGdCQUFnQixDQUFDLE9BQWU7SUFDNUMsT0FBTyxzQkFBYSxDQUFDLEdBQUcsRUFBRTtRQUN0QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3ZDLE1BQU0sSUFBSSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQWMsQ0FBQztJQUN6QyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUFORCw0Q0FNQztBQUVELFNBQWdCLGlCQUFpQixDQUFDLE9BQWUsRUFBRSxLQUFnQjtJQUMvRCxPQUFPLHNCQUFhLENBQUMsR0FBRyxFQUFFO1FBQ3RCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDaEUsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBTkQsOENBTUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIwIEVyaWsgRm9ydHVuZVxuICpcbiAqIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbiAqIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbiAqIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbiAqIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbiAqIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuICogZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbiAqXG4gKiBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbiBhbGxcbiAqIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4gKlxuICogVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuICogSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4gKiBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbiAqIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbiAqIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4gKiBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRVxuICogU09GVFdBUkUuXG4gKi9cblxuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IFJlc3VsdCwgY2FwdHVyZVJlc3VsdCB9IGZyb20gJy4vcmVzdWx0JztcblxuZXhwb3J0IHR5cGUgSnNvblByaW1pdGl2ZSA9IGJvb2xlYW4gfCBudW1iZXIgfCBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkO1xuZXhwb3J0IGludGVyZmFjZSBKc29uT2JqZWN0IHsgW2tleTogc3RyaW5nXTogSnNvblZhbHVlIH1cbmV4cG9ydCB0eXBlIEpzb25WYWx1ZSA9IEpzb25QcmltaXRpdmUgfCBKc29uT2JqZWN0IHwgSnNvbkFycmF5O1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1pbnRlcmZhY2VcbmV4cG9ydCBpbnRlcmZhY2UgSnNvbkFycmF5IGV4dGVuZHMgQXJyYXk8SnNvblZhbHVlPiB7fVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZEpzb25GaWxlU3luYyhzcmNQYXRoOiBzdHJpbmcpOiBSZXN1bHQ8SnNvblZhbHVlPiB7XG4gICAgcmV0dXJuIGNhcHR1cmVSZXN1bHQoKCkgPT4ge1xuICAgICAgICBjb25zdCBmdWxsUGF0aCA9IHBhdGgucmVzb2x2ZShzcmNQYXRoKTtcbiAgICAgICAgY29uc3QgYm9keSA9IGZzLnJlYWRGaWxlU3luYyhmdWxsUGF0aCwgJ3V0ZjgnKS50b1N0cmluZygpO1xuICAgICAgICByZXR1cm4gSlNPTi5wYXJzZShib2R5KSBhcyBKc29uVmFsdWU7XG4gICAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB3cml0ZUpzb25GaWxlU3luYyhzcmNQYXRoOiBzdHJpbmcsIHZhbHVlOiBKc29uVmFsdWUpOiBSZXN1bHQ8Ym9vbGVhbj4ge1xuICAgIHJldHVybiBjYXB0dXJlUmVzdWx0KCgpID0+IHtcbiAgICAgICAgY29uc3QgZnVsbFBhdGggPSBwYXRoLnJlc29sdmUoc3JjUGF0aCk7XG4gICAgICAgIGZzLndyaXRlRmlsZVN5bmMoZnVsbFBhdGgsIEpTT04uc3RyaW5naWZ5KHZhbHVlLCB1bmRlZmluZWQsIDIpKTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSk7XG59XG4iXX0=
function templatedJsonConverter(view) {
return new converter_1.BaseConverter((from, self) => {
if ((from === null) || (typeof from === 'number') || (typeof from === 'boolean')) {
return result_1.succeed(from);
}
if (typeof from === 'string') {
if ((view !== undefined) && from.includes('{{')) {
return result_1.captureResult(() => mustache_1.default.render(from, view));
}
return result_1.succeed(from);
}
if (typeof from !== 'object') {
return result_1.fail(`Cannot convert ${JSON.stringify(from)} to JSON`);
}
if (Array.isArray(from)) {
return converters_1.arrayOf(self, 'failOnError').convert(from);
}
const src = from;
const json = {};
for (const prop in src) {
// istanbul ignore else
if (src.hasOwnProperty(prop)) {
const result = self.convert(src[prop]).onSuccess((v) => {
json[prop] = v;
return result_1.succeed(v);
});
if (result.isFailure()) {
return result;
}
}
}
return result_1.succeed(json);
});
}
exports.templatedJsonConverter = templatedJsonConverter;
exports.jsonConverter = templatedJsonConverter();
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNvbkhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvanNvbkhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVILHVDQUF5QjtBQUN6QiwyQ0FBNkI7QUFDN0IsMkNBQXVEO0FBQ3ZELHFDQUFnRTtBQUVoRSx3REFBZ0M7QUFDaEMsNkNBQXVDO0FBUXZDLFNBQWdCLGdCQUFnQixDQUFDLE9BQWU7SUFDNUMsT0FBTyxzQkFBYSxDQUFDLEdBQUcsRUFBRTtRQUN0QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3ZDLE1BQU0sSUFBSSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQWMsQ0FBQztJQUN6QyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUFORCw0Q0FNQztBQUVELFNBQWdCLGlCQUFpQixDQUFDLE9BQWUsRUFBRSxLQUFnQjtJQUMvRCxPQUFPLHNCQUFhLENBQUMsR0FBRyxFQUFFO1FBQ3RCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDaEUsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBTkQsOENBTUM7QUFFRCxTQUFnQixzQkFBc0IsQ0FBQyxJQUFjO0lBQ2pELE9BQU8sSUFBSSx5QkFBYSxDQUFZLENBQUMsSUFBYSxFQUFFLElBQTBCLEVBQUUsRUFBRTtRQUM5RSxJQUFJLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxJQUFJLEtBQUssUUFBUSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksS0FBSyxTQUFTLENBQUMsRUFBRTtZQUM5RSxPQUFPLGdCQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDeEI7UUFFRCxJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRTtZQUMxQixJQUFJLENBQUMsSUFBSSxLQUFLLFNBQVMsQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQzdDLE9BQU8sc0JBQWEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxrQkFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQzthQUMzRDtZQUNELE9BQU8sZ0JBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUN4QjtRQUVELElBQUksT0FBTyxJQUFJLEtBQUssUUFBUSxFQUFFO1lBQzFCLE9BQU8sYUFBSSxDQUFDLGtCQUFrQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUNqRTtRQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNyQixPQUFPLG9CQUFPLENBQUMsSUFBSSxFQUFFLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNyRDtRQUVELE1BQU0sR0FBRyxHQUFHLElBQWtCLENBQUM7UUFDL0IsTUFBTSxJQUFJLEdBQWUsRUFBRSxDQUFDO1FBQzVCLEtBQUssTUFBTSxJQUFJLElBQUksR0FBRyxFQUFFO1lBQ3BCLHVCQUF1QjtZQUN2QixJQUFJLEdBQUcsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQzFCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7b0JBQ25ELElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7b0JBQ2YsT0FBTyxnQkFBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUN0QixDQUFDLENBQUMsQ0FBQztnQkFDSCxJQUFJLE1BQU0sQ0FBQyxTQUFTLEVBQUUsRUFBRTtvQkFDcEIsT0FBTyxNQUFNLENBQUM7aUJBQ2pCO2FBQ0o7U0FDSjtRQUNELE9BQU8sZ0JBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUFyQ0Qsd0RBcUNDO0FBRVksUUFBQSxhQUFhLEdBQUcsc0JBQXNCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgQmFzZUNvbnZlcnRlciwgQ29udmVydGVyIH0gZnJvbSAnLi9jb252ZXJ0ZXInO1xuaW1wb3J0IHsgUmVzdWx0LCBjYXB0dXJlUmVzdWx0LCBmYWlsLCBzdWNjZWVkIH0gZnJvbSAnLi9yZXN1bHQnO1xuXG5pbXBvcnQgTXVzdGFjaGUgZnJvbSAnbXVzdGFjaGUnO1xuaW1wb3J0IHsgYXJyYXlPZiB9IGZyb20gJy4vY29udmVydGVycyc7XG5cbmV4cG9ydCB0eXBlIEpzb25QcmltaXRpdmUgPSBib29sZWFuIHwgbnVtYmVyIHwgc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcbmV4cG9ydCBpbnRlcmZhY2UgSnNvbk9iamVjdCB7IFtrZXk6IHN0cmluZ106IEpzb25WYWx1ZSB9XG5leHBvcnQgdHlwZSBKc29uVmFsdWUgPSBKc29uUHJpbWl0aXZlIHwgSnNvbk9iamVjdCB8IEpzb25BcnJheTtcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlXG5leHBvcnQgaW50ZXJmYWNlIEpzb25BcnJheSBleHRlbmRzIEFycmF5PEpzb25WYWx1ZT4geyB9XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkSnNvbkZpbGVTeW5jKHNyY1BhdGg6IHN0cmluZyk6IFJlc3VsdDxKc29uVmFsdWU+IHtcbiAgICByZXR1cm4gY2FwdHVyZVJlc3VsdCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IGZ1bGxQYXRoID0gcGF0aC5yZXNvbHZlKHNyY1BhdGgpO1xuICAgICAgICBjb25zdCBib2R5ID0gZnMucmVhZEZpbGVTeW5jKGZ1bGxQYXRoLCAndXRmOCcpLnRvU3RyaW5nKCk7XG4gICAgICAgIHJldHVybiBKU09OLnBhcnNlKGJvZHkpIGFzIEpzb25WYWx1ZTtcbiAgICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHdyaXRlSnNvbkZpbGVTeW5jKHNyY1BhdGg6IHN0cmluZywgdmFsdWU6IEpzb25WYWx1ZSk6IFJlc3VsdDxib29sZWFuPiB7XG4gICAgcmV0dXJuIGNhcHR1cmVSZXN1bHQoKCkgPT4ge1xuICAgICAgICBjb25zdCBmdWxsUGF0aCA9IHBhdGgucmVzb2x2ZShzcmNQYXRoKTtcbiAgICAgICAgZnMud3JpdGVGaWxlU3luYyhmdWxsUGF0aCwgSlNPTi5zdHJpbmdpZnkodmFsdWUsIHVuZGVmaW5lZCwgMikpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRlbXBsYXRlZEpzb25Db252ZXJ0ZXIodmlldz86IHVua25vd24pOiBDb252ZXJ0ZXI8SnNvblZhbHVlPiB7XG4gICAgcmV0dXJuIG5ldyBCYXNlQ29udmVydGVyPEpzb25WYWx1ZT4oKGZyb206IHVua25vd24sIHNlbGY6IENvbnZlcnRlcjxKc29uVmFsdWU+KSA9PiB7XG4gICAgICAgIGlmICgoZnJvbSA9PT0gbnVsbCkgfHwgKHR5cGVvZiBmcm9tID09PSAnbnVtYmVyJykgfHwgKHR5cGVvZiBmcm9tID09PSAnYm9vbGVhbicpKSB7XG4gICAgICAgICAgICByZXR1cm4gc3VjY2VlZChmcm9tKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0eXBlb2YgZnJvbSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIGlmICgodmlldyAhPT0gdW5kZWZpbmVkKSAmJiBmcm9tLmluY2x1ZGVzKCd7eycpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGNhcHR1cmVSZXN1bHQoKCkgPT4gTXVzdGFjaGUucmVuZGVyKGZyb20sIHZpZXcpKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBzdWNjZWVkKGZyb20pO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHR5cGVvZiBmcm9tICE9PSAnb2JqZWN0Jykge1xuICAgICAgICAgICAgcmV0dXJuIGZhaWwoYENhbm5vdCBjb252ZXJ0ICR7SlNPTi5zdHJpbmdpZnkoZnJvbSl9IHRvIEpTT05gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KGZyb20pKSB7XG4gICAgICAgICAgICByZXR1cm4gYXJyYXlPZihzZWxmLCAnZmFpbE9uRXJyb3InKS5jb252ZXJ0KGZyb20pO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgc3JjID0gZnJvbSBhcyBKc29uT2JqZWN0O1xuICAgICAgICBjb25zdCBqc29uOiBKc29uT2JqZWN0ID0ge307XG4gICAgICAgIGZvciAoY29uc3QgcHJvcCBpbiBzcmMpIHtcbiAgICAgICAgICAgIC8vIGlzdGFuYnVsIGlnbm9yZSBlbHNlXG4gICAgICAgICAgICBpZiAoc3JjLmhhc093blByb3BlcnR5KHByb3ApKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVzdWx0ID0gc2VsZi5jb252ZXJ0KHNyY1twcm9wXSkub25TdWNjZXNzKCh2KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGpzb25bcHJvcF0gPSB2O1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gc3VjY2VlZCh2KTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICBpZiAocmVzdWx0LmlzRmFpbHVyZSgpKSB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBzdWNjZWVkKGpzb24pO1xuICAgIH0pO1xufVxuXG5leHBvcnQgY29uc3QganNvbkNvbnZlcnRlciA9IHRlbXBsYXRlZEpzb25Db252ZXJ0ZXIoKTtcbiJdfQ==
{
"name": "@fgv/ts-utils",
"version": "0.1.9",
"version": "0.2.0",
"description": "Assorted Typescript Utilities",

@@ -5,0 +5,0 @@ "main": "index.js",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc