@fgv/ts-utils
Advanced tools
Comparing version 1.4.0 to 1.4.1
@@ -5,5 +5,5 @@ /** | ||
*/ | ||
export declare type Brand<T, B> = T & { | ||
export type Brand<T, B> = T & { | ||
__brand: B; | ||
}; | ||
//# sourceMappingURL=brand.d.ts.map |
import { Result } from './result'; | ||
import { Brand } from './brand'; | ||
declare type OnError = 'failOnError' | 'ignoreErrors'; | ||
type OnError = 'failOnError' | 'ignoreErrors'; | ||
/** | ||
@@ -164,3 +164,3 @@ * Converter traits. | ||
*/ | ||
declare type InnerInferredType<TCONV> = TCONV extends Converter<infer TTO> ? (TTO extends Array<infer TTOELEM> ? InnerInferredType<TTOELEM>[] : TTO) : (TCONV extends Array<infer TELEM> ? InnerInferredType<TELEM>[] : TCONV); | ||
type InnerInferredType<TCONV> = TCONV extends Converter<infer TTO> ? (TTO extends Array<infer TTOELEM> ? InnerInferredType<TTOELEM>[] : TTO) : (TCONV extends Array<infer TELEM> ? InnerInferredType<TELEM>[] : TCONV); | ||
/** | ||
@@ -172,3 +172,3 @@ * Infers the type that will be returned by an intstantiated converter. Works | ||
*/ | ||
export declare type Infer<TCONV> = TCONV extends Converter<infer TTO> ? InnerInferredType<TTO> : never; | ||
export type Infer<TCONV> = TCONV extends Converter<infer TTO> ? InnerInferredType<TTO> : never; | ||
/** | ||
@@ -179,3 +179,3 @@ * Deprecated name for Infer<T> retained for compatibility | ||
*/ | ||
export declare type ConvertedToType<TCONV> = Infer<TCONV>; | ||
export type ConvertedToType<TCONV> = Infer<TCONV>; | ||
/** | ||
@@ -182,0 +182,0 @@ * Base templated wrapper to simplify creation of new {@link Converter}s. |
@@ -5,3 +5,3 @@ import { BaseConverter, Converter, ConverterTraits } from './converter'; | ||
import { ExtendedArray } from './extendedArray'; | ||
declare type OnError = 'failOnError' | 'ignoreErrors'; | ||
type OnError = 'failOnError' | 'ignoreErrors'; | ||
/** | ||
@@ -424,3 +424,3 @@ * Options for {@link Converters.StringConverter | StringConverter} | ||
*/ | ||
export declare type FieldConverters<T, TC = unknown> = { | ||
export type FieldConverters<T, TC = unknown> = { | ||
[key in keyof T]: Converter<T[key], TC>; | ||
@@ -538,3 +538,3 @@ }; | ||
*/ | ||
export declare type StrictObjectConverterOptions<T> = Omit<ObjectConverterOptions<T>, 'strict'>; | ||
export type StrictObjectConverterOptions<T> = Omit<ObjectConverterOptions<T>, 'strict'>; | ||
/** | ||
@@ -584,3 +584,3 @@ * Helper function to create a {@link Converters.ObjectConverter | ObjectConverter} which converts an object | ||
*/ | ||
export declare type DiscriminatedObjectConverters<T, TD extends string = string, TC = unknown> = Record<TD, Converter<T, TC>>; | ||
export type DiscriminatedObjectConverters<T, TD extends string = string, TC = unknown> = Record<TD, Converter<T, TC>>; | ||
/** | ||
@@ -587,0 +587,0 @@ * Helper to create a {@link Converter} which converts a discriminated object without changing shape. |
@@ -46,5 +46,2 @@ "use strict"; | ||
}; | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
@@ -55,3 +52,3 @@ exports.readCsvFileSync = void 0; | ||
const result_1 = require("./result"); | ||
const sync_1 = __importDefault(require("csv-parse/lib/sync")); | ||
const sync_1 = require("csv-parse/sync"); | ||
/** | ||
@@ -68,6 +65,6 @@ * Reads a CSV file from a supplied path. | ||
// eslint-disable-next-line | ||
return (0, sync_1.default)(body, { trim: true, from_line: 2 }); | ||
return (0, sync_1.parse)(body, { trim: true, from_line: 2 }); | ||
}); | ||
} | ||
exports.readCsvFileSync = readCsvFileSync; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3N2SGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jc3ZIZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsdUNBQXlCO0FBQ3pCLDJDQUE2QjtBQUM3QixxQ0FBaUQ7QUFDakQsOERBQXNDO0FBRXRDOzs7OztHQUtHO0FBQ0gsU0FBZ0IsZUFBZSxDQUFDLE9BQWU7SUFDM0MsT0FBTyxJQUFBLHNCQUFhLEVBQUMsR0FBRyxFQUFFO1FBQ3RCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDMUQsMkJBQTJCO1FBQzNCLE9BQU8sSUFBQSxjQUFJLEVBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQyxFQUFDLENBQUMsQ0FBQztJQUNuRCxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUFQRCwwQ0FPQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgUmVzdWx0LCBjYXB0dXJlUmVzdWx0IH0gZnJvbSAnLi9yZXN1bHQnO1xuaW1wb3J0IHN5bmMgZnJvbSAnY3N2LXBhcnNlL2xpYi9zeW5jJztcblxuLyoqXG4gKiBSZWFkcyBhIENTViBmaWxlIGZyb20gYSBzdXBwbGllZCBwYXRoLlxuICogQHBhcmFtIHNyY1BhdGggLSBTb3VyY2UgcGF0aCBmcm9tIHdoaWNoIHRoZSBmaWxlIGlzIHJlYWQuXG4gKiBAcmV0dXJucyBUaGUgY29udGVudHMgb2YgdGhlIGZpbGUuXG4gKiBAYmV0YVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVhZENzdkZpbGVTeW5jKHNyY1BhdGg6IHN0cmluZyk6IFJlc3VsdDx1bmtub3duPiB7XG4gICAgcmV0dXJuIGNhcHR1cmVSZXN1bHQoKCkgPT4ge1xuICAgICAgICBjb25zdCBmdWxsUGF0aCA9IHBhdGgucmVzb2x2ZShzcmNQYXRoKTtcbiAgICAgICAgY29uc3QgYm9keSA9IGZzLnJlYWRGaWxlU3luYyhmdWxsUGF0aCwgJ3V0ZjgnKS50b1N0cmluZygpO1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICAgICAgcmV0dXJuIHN5bmMoYm9keSwgeyB0cmltOiB0cnVlLCBmcm9tX2xpbmU6IDJ9KTtcbiAgICB9KTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3N2SGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jc3ZIZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsdUNBQXlCO0FBQ3pCLDJDQUE2QjtBQUM3QixxQ0FBaUQ7QUFDakQseUNBQXVDO0FBRXZDOzs7OztHQUtHO0FBQ0gsU0FBZ0IsZUFBZSxDQUFDLE9BQWU7SUFDM0MsT0FBTyxJQUFBLHNCQUFhLEVBQUMsR0FBRyxFQUFFO1FBQ3RCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDMUQsMkJBQTJCO1FBQzNCLE9BQU8sSUFBQSxZQUFLLEVBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQyxFQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUFQRCwwQ0FPQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgUmVzdWx0LCBjYXB0dXJlUmVzdWx0IH0gZnJvbSAnLi9yZXN1bHQnO1xuaW1wb3J0IHsgcGFyc2UgfSBmcm9tICdjc3YtcGFyc2Uvc3luYyc7XG5cbi8qKlxuICogUmVhZHMgYSBDU1YgZmlsZSBmcm9tIGEgc3VwcGxpZWQgcGF0aC5cbiAqIEBwYXJhbSBzcmNQYXRoIC0gU291cmNlIHBhdGggZnJvbSB3aGljaCB0aGUgZmlsZSBpcyByZWFkLlxuICogQHJldHVybnMgVGhlIGNvbnRlbnRzIG9mIHRoZSBmaWxlLlxuICogQGJldGFcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlYWRDc3ZGaWxlU3luYyhzcmNQYXRoOiBzdHJpbmcpOiBSZXN1bHQ8dW5rbm93bj4ge1xuICAgIHJldHVybiBjYXB0dXJlUmVzdWx0KCgpID0+IHtcbiAgICAgICAgY29uc3QgZnVsbFBhdGggPSBwYXRoLnJlc29sdmUoc3JjUGF0aCk7XG4gICAgICAgIGNvbnN0IGJvZHkgPSBmcy5yZWFkRmlsZVN5bmMoZnVsbFBhdGgsICd1dGY4JykudG9TdHJpbmcoKTtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgICAgIHJldHVybiBwYXJzZShib2R5LCB7IHRyaW06IHRydWUsIGZyb21fbGluZTogMn0pO1xuICAgIH0pO1xufVxuIl19 |
@@ -6,3 +6,3 @@ import { Result } from './result'; | ||
*/ | ||
export declare type FormatTargets = 'text' | 'markdown' | 'embed'; | ||
export type FormatTargets = 'text' | 'markdown' | 'embed'; | ||
/** | ||
@@ -44,3 +44,3 @@ * Interface for an object that can be formatted. | ||
*/ | ||
export declare type Formatter<T> = (format: string, item: T) => Result<string>; | ||
export type Formatter<T> = (format: string, item: T) => Result<string>; | ||
/** | ||
@@ -51,3 +51,3 @@ * A collection of {@link Formatter | formatters} indexed by target name, to enable | ||
*/ | ||
export declare type FormattersByExtendedTarget<TFT extends FormatTargets, T> = Record<TFT, Formatter<T>>; | ||
export type FormattersByExtendedTarget<TFT extends FormatTargets, T> = Record<TFT, Formatter<T>>; | ||
/** | ||
@@ -58,3 +58,3 @@ * A collection of {@link Formatter | formatters} indexed by the {@link FormatTargets | default supported | ||
*/ | ||
export declare type FormattersByTarget<T> = FormattersByExtendedTarget<FormatTargets, T>; | ||
export type FormattersByTarget<T> = FormattersByExtendedTarget<FormatTargets, T>; | ||
/** | ||
@@ -61,0 +61,0 @@ * Formats a list of items using the supplied template and formatter, one result |
import { Failure, Success } from './result'; | ||
export declare type LogLevel = 'detail' | 'info' | 'warning' | 'error' | 'silent'; | ||
export type LogLevel = 'detail' | 'info' | 'warning' | 'error' | 'silent'; | ||
export interface Logger { | ||
@@ -4,0 +4,0 @@ log(message?: unknown, ...parameters: unknown[]): Success<string | undefined>; |
import { Result } from './result'; | ||
export declare type Entry<T> = [string | number | symbol, T]; | ||
export declare type ResultEntry<T> = [string | number | symbol, Result<T>]; | ||
export type Entry<T> = [string | number | symbol, T]; | ||
export type ResultEntry<T> = [string | number | symbol, Result<T>]; | ||
/** | ||
@@ -5,0 +5,0 @@ * Normalizes an arbitrary JSON object |
{ | ||
"name": "@fgv/ts-utils", | ||
"version": "1.4.0", | ||
"version": "1.4.1", | ||
"description": "Assorted Typescript Utilities", | ||
@@ -34,8 +34,9 @@ "main": "index.js", | ||
"devDependencies": { | ||
"@jest/expect-utils": "^29.3.1", | ||
"@microsoft/api-documenter": "^7.16.0", | ||
"@microsoft/api-extractor": "^7.19.5", | ||
"@types/jest": "^27.0.2", | ||
"@types/luxon": "^2.0.4", | ||
"@types/jest": "^29.2.4", | ||
"@types/luxon": "^3.1.0", | ||
"@types/mustache": "^4.1.2", | ||
"@types/node": "^17.0.21", | ||
"@types/node": "^18.11.12", | ||
"@typescript-eslint/eslint-plugin": "^5.15.0", | ||
@@ -48,7 +49,7 @@ "@typescript-eslint/parser": "^5.15.0", | ||
"eslint-plugin-promise": "^6.0.0", | ||
"jest": "^27.2.4", | ||
"jest-extended": "^2.0.0", | ||
"jest-matcher-utils": "^27.2.4", | ||
"jest": "^29.3.1", | ||
"jest-extended": "^3.2.0", | ||
"jest-matcher-utils": "^29.3.1", | ||
"rimraf": "^3.0.2", | ||
"ts-jest": "^27.0.5", | ||
"ts-jest": "^29.0.3", | ||
"ts-node": "^10.2.1", | ||
@@ -58,6 +59,6 @@ "typescript": "^4.4.3" | ||
"dependencies": { | ||
"csv-parse": "^4.16.3", | ||
"luxon": "^2.0.2", | ||
"csv-parse": "^5.3.3", | ||
"luxon": "^3.1.1", | ||
"mustache": "^4.0.1" | ||
} | ||
} |
@@ -5,6 +5,6 @@ /** | ||
* {@link Success | Success<T>} and {@link Failure | Failure<T>} share the common | ||
* contract {@link IResult}, enabling comingled discriminated usage. | ||
* contract {@link IResult}, enabling commingled discriminated usage. | ||
* @public | ||
*/ | ||
export declare type Result<T> = Success<T> | Failure<T>; | ||
export type Result<T> = Success<T> | Failure<T>; | ||
/** | ||
@@ -15,3 +15,3 @@ * Continuation callback to be called in the event that an | ||
*/ | ||
export declare type SuccessContinuation<T, TN> = (value: T) => Result<TN>; | ||
export type SuccessContinuation<T, TN> = (value: T) => Result<TN>; | ||
/** | ||
@@ -22,3 +22,3 @@ * Continuation callback to be called in the event that an | ||
*/ | ||
export declare type FailureContinuation<T> = (message: string) => Result<T>; | ||
export type FailureContinuation<T> = (message: string) => Result<T>; | ||
/** | ||
@@ -28,3 +28,3 @@ * Type inference to determine the result type of an {@link Result}. | ||
*/ | ||
export declare type ResultValueType<T> = T extends Result<infer TV> ? TV : never; | ||
export type ResultValueType<T> = T extends Result<infer TV> ? TV : never; | ||
/** | ||
@@ -44,3 +44,3 @@ * Simple logger interface used by {@link IResult.getValueOrThrow}. | ||
* @remarks | ||
* This common contract enables comingled discriminated usage of {@link Success | Success<T>} | ||
* This common contract enables commingled discriminated usage of {@link Success | Success<T>} | ||
* and {@link Failure | Failure<T>}. | ||
@@ -124,3 +124,3 @@ * @public | ||
* the success result or the error message from this {@link IResult} and the | ||
* appopriate added detail. | ||
* appropriate added detail. | ||
*/ | ||
@@ -266,3 +266,3 @@ withDetail<TD>(detail: TD, successDetail?: TD): DetailedResult<T, TD>; | ||
*/ | ||
export declare type DetailedSuccessContinuation<T, TD, TN> = (value: T, detail?: TD) => DetailedResult<TN, TD>; | ||
export type DetailedSuccessContinuation<T, TD, TN> = (value: T, detail?: TD) => DetailedResult<TN, TD>; | ||
/** | ||
@@ -275,3 +275,3 @@ * Callback to be called when a {@link DetailedResult} encounters a failure. | ||
*/ | ||
export declare type DetailedFailureContinuation<T, TD> = (message: string, detail: TD) => DetailedResult<T, TD>; | ||
export type DetailedFailureContinuation<T, TD> = (message: string, detail: TD) => DetailedResult<T, TD>; | ||
/** | ||
@@ -381,3 +381,3 @@ * A {@link DetailedSuccess} extends {@link Success} to report optional success details in | ||
*/ | ||
export declare type DetailedResult<T, TD> = DetailedSuccess<T, TD> | DetailedFailure<T, TD>; | ||
export type DetailedResult<T, TD> = DetailedSuccess<T, TD> | DetailedFailure<T, TD>; | ||
/** | ||
@@ -387,3 +387,3 @@ * Type inference to determine the detail type `TD` of a {@link DetailedResult | DetailedResult<T, TD>}. | ||
*/ | ||
export declare type ResultDetailType<T> = T extends DetailedResult<unknown, infer TD> ? TD : never; | ||
export type ResultDetailType<T> = T extends DetailedResult<unknown, infer TD> ? TD : never; | ||
/** | ||
@@ -431,3 +431,3 @@ * Returns {@link DetailedSuccess | DetailedSuccess<T, TD>} with a supplied value and optional | ||
/** | ||
* Aggregates sucessful result values from a collection of {@link Result | Result<T>}. | ||
* Aggregates successful result values from a collection of {@link Result | Result<T>}. | ||
* @param results - The collection of {@link Result | Result<T>} to be mapped. | ||
@@ -441,3 +441,3 @@ * @returns If all {@link Result | results} are successful, returns {@link Success} with an | ||
/** | ||
* Aggregates sucessful results from a collection of {@link DetailedResult | DetailedResult<T, TD>}, | ||
* Aggregates successful results from a collection of {@link DetailedResult | DetailedResult<T, TD>}, | ||
* optionally ignoring certain error details. | ||
@@ -447,5 +447,5 @@ * @param results - The collection of {@link DetailedResult | DetailedResult<T, TD>} to be mapped. | ||
* @returns {@link Success} with an array containing all successful results if all results either | ||
* suceeded or returned error details listed in `ignore`. If any results failed with details | ||
* succeeded or returned error details listed in `ignore`. If any results failed with details | ||
* that cannot be ignored, returns {@link Failure} with an concatenated summary of all non-ignorable | ||
* error mesasges. | ||
* error messages. | ||
* @public | ||
@@ -466,3 +466,3 @@ */ | ||
* Aggregates error messages from a collection of {@link Result | Result<T>}. | ||
* @param results - An interable collection of {@link Result | Result<T>} for which | ||
* @param results - An iterable collection of {@link Result | Result<T>} for which | ||
* error messages are aggregated. | ||
@@ -488,3 +488,3 @@ * @returns An array of strings consisting of all error messages returned by | ||
*/ | ||
export declare type FieldInitializers<T> = { | ||
export type FieldInitializers<T> = { | ||
[key in keyof T]: (state: Partial<T>) => Result<T[key]>; | ||
@@ -491,0 +491,0 @@ }; |
@@ -378,3 +378,3 @@ "use strict"; | ||
/** | ||
* Aggregates sucessful result values from a collection of {@link Result | Result<T>}. | ||
* Aggregates successful result values from a collection of {@link Result | Result<T>}. | ||
* @param results - The collection of {@link Result | Result<T>} to be mapped. | ||
@@ -404,3 +404,3 @@ * @returns If all {@link Result | results} are successful, returns {@link Success} with an | ||
/** | ||
* Aggregates sucessful results from a collection of {@link DetailedResult | DetailedResult<T, TD>}, | ||
* Aggregates successful results from a collection of {@link DetailedResult | DetailedResult<T, TD>}, | ||
* optionally ignoring certain error details. | ||
@@ -410,5 +410,5 @@ * @param results - The collection of {@link DetailedResult | DetailedResult<T, TD>} to be mapped. | ||
* @returns {@link Success} with an array containing all successful results if all results either | ||
* suceeded or returned error details listed in `ignore`. If any results failed with details | ||
* succeeded or returned error details listed in `ignore`. If any results failed with details | ||
* that cannot be ignored, returns {@link Failure} with an concatenated summary of all non-ignorable | ||
* error mesasges. | ||
* error messages. | ||
* @public | ||
@@ -461,3 +461,3 @@ */ | ||
* Aggregates error messages from a collection of {@link Result | Result<T>}. | ||
* @param results - An interable collection of {@link Result | Result<T>} for which | ||
* @param results - An iterable collection of {@link Result | Result<T>} for which | ||
* error messages are aggregated. | ||
@@ -534,3 +534,3 @@ * @returns An array of strings consisting of all error messages returned by | ||
else { | ||
errors.push(`populateObject: Key ${key} is present but has no initializer`); | ||
errors.push(`populateObject: Key ${String(key)} is present but has no initializer`); | ||
} | ||
@@ -544,2 +544,2 @@ } | ||
exports.populateObject = populateObject; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"result.js","sourceRoot":"","sources":["../src/result.ts"],"names":[],"mappings":"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","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 */\n\n/* eslint-disable no-use-before-define */\n/**\n * Represents the {@link IResult | result} of some operation or sequence of operations.\n * @remarks\n * {@link Success | Success<T>} and {@link Failure | Failure<T>} share the common\n * contract {@link IResult}, enabling comingled discriminated usage.\n * @public\n */\nexport type Result<T> = Success<T> | Failure<T>;\n/**\n * Continuation callback to be called in the event that an\n * {@link Result} is successful.\n * @public\n */\nexport type SuccessContinuation<T, TN> = (value: T) => Result<TN>;\n/**\n * Continuation callback to be called in the event that an\n * {@link Result} fails.\n * @public\n */\nexport type FailureContinuation<T> = (message: string) => Result<T>;\n/**\n * Type inference to determine the result type of an {@link Result}.\n * @beta\n */\nexport type ResultValueType<T> = T extends Result<infer TV> ? TV : never;\n\n/**\n * Simple logger interface used by {@link IResult.getValueOrThrow}.\n * @public\n */\nexport interface IResultLogger {\n    /**\n     * Log an error message.\n     * @param message - The message to be logged.\n     */\n    error(message: string): void;\n}\n\n/**\n * Represents the result of some operation of sequence of operations.\n * @remarks\n * This common contract enables comingled discriminated usage of {@link Success | Success<T>}\n * and {@link Failure | Failure<T>}.\n * @public\n */\nexport interface IResult<T> {\n    /**\n     * Indicates whether the operation was successful.\n     */\n    readonly success: boolean;\n\n    /**\n     * Indicates whether this operation was successful.  Functions\n     * as a type guard for {@link Success | Success<T>}.\n     */\n    isSuccess(): this is Success<T>;\n\n    /**\n     * Indicates whether this operation failed.  Functions\n     * as a type guard for {@link Failure | Failure<T>}.\n     */\n    isFailure(): this is Failure<T>;\n\n    /**\n     * Gets the value associated with a successful {@link IResult | result},\n     * or throws the error message if the corresponding operation failed.\n     * @param logger - An optional {@link IResultLogger | logger} to which the\n     * error will also be reported.\n     * @returns The return value, if the operation was successful.\n     * @throws The error message if the operation failed.\n     */\n    getValueOrThrow(logger?: IResultLogger): T;\n\n    /**\n     * Gets the value associated with a successful {@link IResult | result},\n     * or a default value if the corresponding operation failed.\n     * @param dflt - The value to be returned if the operation failed (default is\n     * `undefined`).\n     * @returns The return value, if the operation was successful.  Returns\n     * the supplied default value or `undefined` if no default is supplied.\n     */\n    getValueOrDefault(dflt?: T): T|undefined;\n\n    /**\n     * Calls a supplied {@link SuccessContinuation | success continuation} if\n     * the operation was a success.\n     * @remarks\n     * The {@link SuccessContinuation | success continuation} might return a\n     * different result type than {@link IResult} on which it is invoked. This\n     * enables chaining of operations with heterogenous return types.\n     *\n     * @param cb - The {@link SuccessContinuation | success continuation} to\n     * be called in the event of success.\n     * @returns If this operation was successful, returns the value returned\n     * by the {@link SuccessContinuation | success continuation}.  If this result\n     * failed, propagates the error message from this failure.\n     */\n    onSuccess<TN>(cb: SuccessContinuation<T, TN>): Result<TN>;\n\n    /**\n     * Calls a supplied {@link FailureContinuation | failed continuation} if\n     * the operation failed.\n     * @param cb - The {@link FailureContinuation | failure continuation} to\n     * be called in the event of failure.\n     * @returns If this operation failed, returns the value returned by the\n     * {@link FailureContinuation | failure continuation}.  If this result\n     * was successful, propagates the result value from the successful event.\n     */\n    onFailure(cb: FailureContinuation<T>): Result<T>;\n\n    /**\n     * Converts a {@link IResult | IResult<T>} to a {@link DetailedResult | DetailedResult<T, TD>},\n     * adding a supplied detail if the operation failed.\n     * @param detail - The detail to be added if this operation failed.\n     * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with either\n     * the success result or the error message from this {@link IResult}, with\n     * the supplied detail (if this event failed) or detail `undefined` (if\n     * this result succeeded).\n     */\n    withFailureDetail<TD>(detail: TD): DetailedResult<T, TD>;\n\n    /**\n     * Converts a {@link IResult | IResult<T>} to a {@link DetailedResult | DetailedResult<T, TD>},\n     * adding supplied details.\n     * @param detail - The default detail to be added to the new {@link DetailedResult}.\n     * @param successDetail - An optional detail to be added if this result was successful.\n     * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with either\n     * the success result or the error message from this {@link IResult} and the\n     * appopriate added detail.\n     */\n    withDetail<TD>(detail: TD, successDetail?: TD): DetailedResult<T, TD>;\n}\n\n/**\n * Reports a successful {@link IResult | result} from some operation and the\n * corresponding value.\n * @public\n */\nexport class Success<T> implements IResult<T> {\n    /**\n     * {@inheritdoc IResult.success}\n     */\n    public readonly success = true;\n    /**\n     * @internal\n     */\n    private readonly _value: T;\n\n    /**\n     * Constructs a {@link Success} with the supplied value.\n     * @param value - The value to be returned.\n     */\n    constructor(value: T) {\n        this._value = value;\n    }\n\n    /**\n     * The result value returned by the successful operation.\n     */\n    public get value(): T {\n        return this._value;\n    }\n\n    /**\n     * {@inheritdoc IResult.isSuccess}\n     */\n    public isSuccess(): this is Success<T> {\n        return true;\n    }\n\n    /**\n     * {@inheritdoc IResult.isFailure}\n     */\n    public isFailure(): this is Failure<T> {\n        return false;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrThrow}\n     */\n    public getValueOrThrow(_logger?: IResultLogger): T {\n        return this._value;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrDefault}\n     */\n    public getValueOrDefault(dflt?: T): T|undefined {\n        return this._value ?? dflt;\n    }\n\n    /**\n     * {@inheritdoc IResult.onSuccess}\n     */\n    public onSuccess<TN>(cb: SuccessContinuation<T, TN>): Result<TN> {\n        return cb(this.value);\n    }\n\n    /**\n     * {@inheritdoc IResult.onFailure}\n     */\n    public onFailure(_: FailureContinuation<T>): Result<T> {\n        return this;\n    }\n\n    /**\n     * {@inheritdoc IResult.withFailureDetail}\n     */\n    public withFailureDetail<TD>(_detail: TD): DetailedResult<T, TD> {\n        return succeedWithDetail(this.value);\n    }\n\n    /**\n     * {@inheritdoc IResult.withDetail}\n     */\n    public withDetail<TD>(detail: TD, successDetail?: TD): DetailedResult<T, TD> {\n        return succeedWithDetail(this.value, successDetail ?? detail);\n    }\n}\n\n/**\n * Reports a failed {@link IResult | result} from some operation, with an error message.\n * @public\n */\nexport class Failure<T> implements IResult<T> {\n    /**\n     * {@inheritdoc IResult.success}\n     */\n    public readonly success = false;\n\n    /**\n     * @internal\n     */\n    private readonly _message: string;\n\n    /**\n     * Constructs a {@link Failure} with the supplied message.\n     * @param message - Error message to be reported.\n     */\n    constructor(message: string) {\n        this._message = message;\n    }\n\n    /**\n     * Gets the error message associated with this error.\n     */\n    public get message(): string {\n        return this._message;\n    }\n\n    /**\n     * {@inheritdoc IResult.isSuccess}\n     */\n    public isSuccess(): this is Success<T> {\n        return false;\n    }\n\n    /**\n     * {@inheritdoc IResult.isFailure}\n     */\n    public isFailure(): this is Failure<T> {\n        return true;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrThrow}\n     */\n    public getValueOrThrow(logger?: IResultLogger): never {\n        if (logger !== undefined) {\n            logger.error(this._message);\n        }\n        throw new Error(this._message);\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrDefault}\n     */\n    public getValueOrDefault(dflt?: T): T|undefined {\n        return dflt;\n    }\n\n    /**\n     * {@inheritdoc IResult.onSuccess}\n     */\n    public onSuccess<TN>(_: SuccessContinuation<T, TN>): Result<TN> {\n        return new Failure(this.message);\n    }\n\n    /**\n     * {@inheritdoc IResult.onFailure}\n     */\n    public onFailure(cb: FailureContinuation<T>): Result<T> {\n        return cb(this.message);\n    }\n\n    /**\n     * {@inheritdoc IResult.withFailureDetail}\n     */\n    public withFailureDetail<TD>(detail: TD): DetailedResult<T, TD> {\n        return failWithDetail(this.message, detail);\n    }\n\n    /**\n     * {@inheritdoc IResult.withDetail}\n     */\n    public withDetail<TD>(detail: TD, _successDetail?: TD): DetailedResult<T, TD> {\n        return failWithDetail(this.message, detail);\n    }\n\n    /**\n     * Get a 'friendly' string representation of this object.\n     * @remarks\n     * The string representation of a {@link Failure} value is the error message.\n     * @returns A string representing this object.\n     */\n    public toString(): string {\n        return this.message;\n    }\n}\n\n/**\n * Returns {@link Success | Success<T>} with the supplied result value.\n * @param value - The successful result value to be returned\n * @public\n */\nexport function succeed<T>(value: T): Success<T> {\n    return new Success<T>(value);\n}\n\n/**\n * Returns {@link Failure | Failure<T>} with the supplied error message.\n * @param message - Error message to be returned.\n * @public\n */\nexport function fail<T>(message: string): Failure<T> {\n    return new Failure<T>(message);\n}\n\n/**\n * Callback to be called when a {@link DetailedResult} encounters success.\n * @remarks\n * A success callback can return a different result type than it receives, allowing\n * success results to chain through intermediate result types.\n * @public\n */\nexport type DetailedSuccessContinuation<T, TD, TN> = (value: T, detail?: TD) => DetailedResult<TN, TD>;\n\n/**\n * Callback to be called when a {@link DetailedResult} encounters a failure.\n * @remarks\n * A failure callback can change {@link Failure} to {@link Success} (e.g. by returning a default value)\n * or it can change or embellish the error message, but it cannot change the success return type.\n * @public\n */\nexport type DetailedFailureContinuation<T, TD> = (message: string, detail: TD) => DetailedResult<T, TD>;\n\n/**\n * A {@link DetailedSuccess} extends {@link Success} to report optional success details in\n * addition to the error message.\n * @public\n */\nexport class DetailedSuccess<T, TD> extends Success<T> {\n    /**\n     * @internal\n     */\n    protected _detail?: TD;\n\n    /**\n     * Constructs a new {@link DetailedSuccess | DetailedSuccess<T, TD>} with the supplied\n     * value and detail.\n     * @param value - The value to be returned.\n     * @param detail - An optional successful detail to be returned.  If omitted, detail\n     * will be `undefined`.\n     */\n    public constructor(value: T, detail?: TD) {\n        super(value);\n        this._detail = detail;\n    }\n\n    /**\n     * The success detail associated with this {@link DetailedSuccess}, or `undefined` if\n     * no detail was supplied.\n     */\n    public get detail(): TD|undefined {\n        return this._detail;\n    }\n\n    /**\n     * Reports that this {@link DetailedSuccess} is a success.\n     * @remarks\n     * Always true for {@link DetailedSuccess} but can be used as type guard\n     * to discriminate {@link DetailedSuccess} from {@link DetailedFailure} in\n     * a {@link DetailedResult}.\n     * @returns `true`\n     */\n    public isSuccess(): this is DetailedSuccess<T, TD> {\n        return true;\n    }\n\n    /**\n     * Invokes the supplied {@link DetailedSuccessContinuation | success callback} and propagates\n     * its returned {@link DetailedResult | DetailedResult<TN, TD>}.\n     * @remarks\n     * The success callback mutates the return type from `<T>` to `<TN>`.\n     * @param cb - The {@link DetailedSuccessContinuation | success callback} to be invoked.\n     * @returns The {@link DetailedResult | DetailedResult<T, TD>} returned by the success callback.\n     */\n    public onSuccess<TN>(cb: DetailedSuccessContinuation<T, TD, TN>): DetailedResult<TN, TD> {\n        return cb(this.value, this._detail);\n    }\n\n    /**\n     * Propagates this {@link DetailedSuccess}.\n     * @remarks\n     * Failure does not mutate return type so we can return this event directly.\n     * @param _cb - {@link DetailedFailureContinuation | Failure callback} to be called\n     * on a {@link DetailedResult} in case of failure (ignored).\n     * @returns `this`\n     */\n    public onFailure(_cb: DetailedFailureContinuation<T, TD>): DetailedResult<T, TD> {\n        return this;\n    }\n}\n\n/**\n * A {@link DetailedFailure} extends {@link Failure} to report optional failure details in\n * addition to the error message.\n * @public\n */\nexport class DetailedFailure<T, TD> extends Failure<T> {\n    /**\n     * @internal\n     */\n    protected _detail: TD;\n\n    /**\n     * Constructs a new {@link DetailedFailure | DetailedFailure<T, TD>} with the supplied\n     * message and detail.\n     * @param message - The message to be returned.\n     * @param detail - The error detail to be returned.\n     */\n    public constructor(message: string, detail: TD) {\n        super(message);\n        this._detail = detail;\n    }\n\n    /**\n     * The error detail associated with this {@link DetailedFailure}.\n     */\n    public get detail(): TD {\n        return this._detail;\n    }\n\n    /**\n     * Reports that this {@link DetailedFailure} is a failure.\n     * @remarks\n     * Always true for {@link DetailedFailure} but can be used as type guard\n     * to discriminate {@link DetailedSuccess} from {@link DetailedFailure} in\n     * a {@link DetailedResult}.\n     * @returns `true`\n     */\n    public isFailure(): this is DetailedFailure<T, TD> {\n        return true;\n    }\n\n    /**\n     * Propagates the error message and detail from this result.\n     * @remarks\n     * Mutates the success type as the success callback would have, but does not\n     * call the success callback.\n     * @param _cb - {@link DetailedSuccessContinuation | Success callback} to be called\n     * on a {@link DetailedResult} in case of success (ignored).\n     * @returns A new {@link DetailedFailure | DetailedFailure<TN, TD>} which contains\n     * the error message and detail from this one.\n     */\n    public onSuccess<TN>(_cb: DetailedSuccessContinuation<T, TD, TN>): DetailedResult<TN, TD> {\n        return new DetailedFailure<TN, TD>(this.message, this._detail);\n    }\n\n    /**\n     * Invokes the supplied {@link DetailedFailureContinuation | failure callback} and propagates\n     * its returned {@link DetailedResult | DetailedResult<T, TD>}.\n     * @param cb - The {@link DetailedFailureContinuation | failure callback} to be invoked.\n     * @returns The {@link DetailedResult | DetailedResult<T, TD>} returned by the failure callback.\n     */\n    public onFailure(cb: DetailedFailureContinuation<T, TD>): DetailedResult<T, TD> {\n        return cb(this.message, this._detail);\n    }\n}\n\n/**\n * Type inference to determine the result type `T` of a {@link DetailedResult | DetailedResult<T, TD>}.\n * @beta\n */\nexport type DetailedResult<T, TD> = DetailedSuccess<T, TD>|DetailedFailure<T, TD>;\n\n/**\n * Type inference to determine the detail type `TD` of a {@link DetailedResult | DetailedResult<T, TD>}.\n * @beta\n */\nexport type ResultDetailType<T> = T extends DetailedResult<unknown, infer TD> ? TD : never;\n\n/**\n * Returns {@link DetailedSuccess | DetailedSuccess<T, TD>} with a supplied value and optional\n * detail.\n * @param value - The value of type `<T>` to be returned.\n * @param detail - An optional detail of type `<TD>` to be returned.\n * @returns A {@link DetailedSuccess | DetailedSuccess<T, TD>} with the supplied value\n * and detail, if supplied.\n * @public\n */\nexport function succeedWithDetail<T, TD>(value: T, detail?: TD): DetailedSuccess<T, TD> {\n    return new DetailedSuccess<T, TD>(value, detail);\n}\n\n/**\n * Returns {@link DetailedFailure | DetailedFailure<T, TD>} with a supplied error message and detail.\n * @param message - The error message to be returned.\n * @param detail - The event detail to be returned.\n * @returns An {@link DetailedFailure | DetailedFailure<T, TD>} with the supplied error\n * message and detail.\n * @public\n */\nexport function failWithDetail<T, TD>(message: string, detail: TD): DetailedFailure<T, TD> {\n    return new DetailedFailure<T, TD>(message, detail);\n}\n\n/**\n * Propagates a {@link Success} or {@link Failure} {@link Result}, adding supplied\n * event details as appropriate.\n * @param result - The {@link Result} to be propagated.\n * @param detail - The event detail (type `<TD>`) to be added to the {@link Result | result}.\n * @param successDetail - An optional distinct event detail to be added to {@link Success} results.  If `successDetail`\n * is omitted or `undefined`, then `detail` will be applied to {@link Success} results.\n * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with the success value or error\n * message from the original `result` but with the specified detail added.\n * @public\n */\nexport function propagateWithDetail<T, TD>(result: Result<T>, detail: TD, successDetail?: TD): DetailedResult<T, TD> {\n    return result.isSuccess()\n        ? succeedWithDetail(result.value, successDetail ?? detail)\n        : failWithDetail(result.message, detail);\n}\n\n/**\n * Wraps a function which might throw to convert exception results\n * to {@link Failure}.\n * @param func - The function to be captured.\n * @returns Returns {@link Success} with a value of type `<T>` on\n * success , or {@link Failure} with the thrown error message if\n * `func` throws an `Error`.\n * @public\n */\nexport function captureResult<T>(func: () => T): Result<T> {\n    try {\n        return succeed(func());\n    }\n    catch (err) {\n        return fail((err as Error).message);\n    }\n}\n\n/**\n * Aggregates sucessful result values from a collection of {@link Result | Result<T>}.\n * @param results - The collection of {@link Result | Result<T>} to be mapped.\n * @returns  If all {@link Result | results} are successful, returns {@link Success} with an\n * array containing all returned values.  If any {@link Result | results} failed, returns\n * {@link Failure} with a concatenated summary of all error messages.\n * @public\n */\nexport function mapResults<T>(results: Iterable<Result<T>>): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else {\n            errors.push(result.message);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates sucessful results from a collection of {@link DetailedResult | DetailedResult<T, TD>},\n * optionally ignoring certain error details.\n * @param results - The collection of {@link DetailedResult | DetailedResult<T, TD>} to be mapped.\n * @param ignore - An array of error detail values (of type `<TD>`) that should be ignored.\n * @returns {@link Success} with an array containing all successful results if all results either\n * suceeded or returned error details listed in `ignore`.  If any results failed with details\n * that cannot be ignored, returns {@link Failure} with an concatenated summary of all non-ignorable\n * error mesasges.\n * @public\n */\nexport function mapDetailedResults<T, TD>(results: Iterable<DetailedResult<T, TD>>, ignore: TD[]): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else if (!ignore.includes(result.detail)) {\n            errors.push(result.message);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates successful results from a a collection of {@link Result | Result<T>}.\n * @param results - An `Iterable` of {@link Result | Result<T>} from which success\n * results are to be aggregated.\n * @returns {@link Success} with an array of `<T>` if any results were successful. If\n * all {@link Result | results} failed, returns {@link Failure} with a concatenated\n * summary of all error messages.\n * @public\n */\nexport function mapSuccess<T>(results: Iterable<Result<T>>): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else {\n            errors.push(result.message);\n        }\n    }\n\n    if ((elements.length === 0) && (errors.length > 0)) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates error messages from a collection of {@link Result | Result<T>}.\n * @param results - An interable collection of {@link Result | Result<T>} for which\n * error messages are aggregated.\n * @returns An array of strings consisting of all error messages returned by\n * {@link Result | results} in the source collection. Ignores {@link Success}\n * results and returns an empty array if there were no errors.\n * @public\n */\nexport function mapFailures<T>(results: Iterable<Result<T>>): string[] {\n    const errors: string[] = [];\n    for (const result of results) {\n        if (result.isFailure()) {\n            errors.push(result.message);\n        }\n    }\n    return errors;\n}\n\n/**\n * Determines if an iterable collection of {@link Result | Result<T>} were all successful.\n * @param results - The collection of {@link Result | Result<T>} to be tested.\n * @returns Returns {@link Success} with `true` if all {@link Result | results} are successful.\n * If any are unsuccessful, returns {@link Failure} with a concatenated summary the error\n * messages from all failed elements.\n * @public\n */\nexport function allSucceed<T>(results: Iterable<Result<unknown>>, successValue: T): Result<T> {\n    const errors: string[] = [];\n\n    // istanbul ignore else\n    if (results !== undefined) {\n        for (const result of results) {\n            if (result.isFailure()) {\n                errors.push(result.message);\n            }\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(successValue);\n}\n\n/**\n * String-keyed record of initialization functions to be passed to {@link populateObject}.\n * @public\n */\nexport type FieldInitializers<T> = { [ key in keyof T ]: (state: Partial<T>) => Result<T[key]> };\n\n/**\n * Populates an an object based on a prototype full of field initializers that return {@link Result | Result<T[key]>}.\n * Returns {@link Success} with the populated object if all initializers succeed, or {@link Failure} with a\n * concatenated list of all error messages.\n * @param initializers - An object with the shape of the target but with initializer functions for\n * each property.\n * @public\n */\nexport function populateObject<T>(initializers: FieldInitializers<T>, order?: (keyof T)[]): Result<T> {\n    const state = {} as { [key in keyof T]: T[key] };\n    const errors: string[] = [];\n    const keys: (keyof T)[] = Array.from(order ?? []);\n    const foundKeys = new Set<keyof T>(order);\n\n    // start with the supplied order then append anything else we find\n    for (const key in initializers) {\n        if (!foundKeys.has(key)) {\n            keys.push(key);\n            foundKeys.add(key);\n        }\n    }\n\n    for (const key of keys) {\n        if (initializers[key]) {\n            const result = initializers[key](state);\n            if (result.isSuccess()) {\n                state[key] = result.value;\n            }\n            else {\n                errors.push(result.message);\n            }\n        }\n        else {\n            errors.push(`populateObject: Key ${key} is present but has no initializer`);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(state as T);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"result.js","sourceRoot":"","sources":["../src/result.ts"],"names":[],"mappings":"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","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 */\n\n/* eslint-disable no-use-before-define */\n/**\n * Represents the {@link IResult | result} of some operation or sequence of operations.\n * @remarks\n * {@link Success | Success<T>} and {@link Failure | Failure<T>} share the common\n * contract {@link IResult}, enabling commingled discriminated usage.\n * @public\n */\nexport type Result<T> = Success<T> | Failure<T>;\n/**\n * Continuation callback to be called in the event that an\n * {@link Result} is successful.\n * @public\n */\nexport type SuccessContinuation<T, TN> = (value: T) => Result<TN>;\n/**\n * Continuation callback to be called in the event that an\n * {@link Result} fails.\n * @public\n */\nexport type FailureContinuation<T> = (message: string) => Result<T>;\n/**\n * Type inference to determine the result type of an {@link Result}.\n * @beta\n */\nexport type ResultValueType<T> = T extends Result<infer TV> ? TV : never;\n\n/**\n * Simple logger interface used by {@link IResult.getValueOrThrow}.\n * @public\n */\nexport interface IResultLogger {\n    /**\n     * Log an error message.\n     * @param message - The message to be logged.\n     */\n    error(message: string): void;\n}\n\n/**\n * Represents the result of some operation of sequence of operations.\n * @remarks\n * This common contract enables commingled discriminated usage of {@link Success | Success<T>}\n * and {@link Failure | Failure<T>}.\n * @public\n */\nexport interface IResult<T> {\n    /**\n     * Indicates whether the operation was successful.\n     */\n    readonly success: boolean;\n\n    /**\n     * Indicates whether this operation was successful.  Functions\n     * as a type guard for {@link Success | Success<T>}.\n     */\n    isSuccess(): this is Success<T>;\n\n    /**\n     * Indicates whether this operation failed.  Functions\n     * as a type guard for {@link Failure | Failure<T>}.\n     */\n    isFailure(): this is Failure<T>;\n\n    /**\n     * Gets the value associated with a successful {@link IResult | result},\n     * or throws the error message if the corresponding operation failed.\n     * @param logger - An optional {@link IResultLogger | logger} to which the\n     * error will also be reported.\n     * @returns The return value, if the operation was successful.\n     * @throws The error message if the operation failed.\n     */\n    getValueOrThrow(logger?: IResultLogger): T;\n\n    /**\n     * Gets the value associated with a successful {@link IResult | result},\n     * or a default value if the corresponding operation failed.\n     * @param dflt - The value to be returned if the operation failed (default is\n     * `undefined`).\n     * @returns The return value, if the operation was successful.  Returns\n     * the supplied default value or `undefined` if no default is supplied.\n     */\n    getValueOrDefault(dflt?: T): T|undefined;\n\n    /**\n     * Calls a supplied {@link SuccessContinuation | success continuation} if\n     * the operation was a success.\n     * @remarks\n     * The {@link SuccessContinuation | success continuation} might return a\n     * different result type than {@link IResult} on which it is invoked. This\n     * enables chaining of operations with heterogenous return types.\n     *\n     * @param cb - The {@link SuccessContinuation | success continuation} to\n     * be called in the event of success.\n     * @returns If this operation was successful, returns the value returned\n     * by the {@link SuccessContinuation | success continuation}.  If this result\n     * failed, propagates the error message from this failure.\n     */\n    onSuccess<TN>(cb: SuccessContinuation<T, TN>): Result<TN>;\n\n    /**\n     * Calls a supplied {@link FailureContinuation | failed continuation} if\n     * the operation failed.\n     * @param cb - The {@link FailureContinuation | failure continuation} to\n     * be called in the event of failure.\n     * @returns If this operation failed, returns the value returned by the\n     * {@link FailureContinuation | failure continuation}.  If this result\n     * was successful, propagates the result value from the successful event.\n     */\n    onFailure(cb: FailureContinuation<T>): Result<T>;\n\n    /**\n     * Converts a {@link IResult | IResult<T>} to a {@link DetailedResult | DetailedResult<T, TD>},\n     * adding a supplied detail if the operation failed.\n     * @param detail - The detail to be added if this operation failed.\n     * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with either\n     * the success result or the error message from this {@link IResult}, with\n     * the supplied detail (if this event failed) or detail `undefined` (if\n     * this result succeeded).\n     */\n    withFailureDetail<TD>(detail: TD): DetailedResult<T, TD>;\n\n    /**\n     * Converts a {@link IResult | IResult<T>} to a {@link DetailedResult | DetailedResult<T, TD>},\n     * adding supplied details.\n     * @param detail - The default detail to be added to the new {@link DetailedResult}.\n     * @param successDetail - An optional detail to be added if this result was successful.\n     * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with either\n     * the success result or the error message from this {@link IResult} and the\n     * appropriate added detail.\n     */\n    withDetail<TD>(detail: TD, successDetail?: TD): DetailedResult<T, TD>;\n}\n\n/**\n * Reports a successful {@link IResult | result} from some operation and the\n * corresponding value.\n * @public\n */\nexport class Success<T> implements IResult<T> {\n    /**\n     * {@inheritdoc IResult.success}\n     */\n    public readonly success = true;\n    /**\n     * @internal\n     */\n    private readonly _value: T;\n\n    /**\n     * Constructs a {@link Success} with the supplied value.\n     * @param value - The value to be returned.\n     */\n    constructor(value: T) {\n        this._value = value;\n    }\n\n    /**\n     * The result value returned by the successful operation.\n     */\n    public get value(): T {\n        return this._value;\n    }\n\n    /**\n     * {@inheritdoc IResult.isSuccess}\n     */\n    public isSuccess(): this is Success<T> {\n        return true;\n    }\n\n    /**\n     * {@inheritdoc IResult.isFailure}\n     */\n    public isFailure(): this is Failure<T> {\n        return false;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrThrow}\n     */\n    public getValueOrThrow(_logger?: IResultLogger): T {\n        return this._value;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrDefault}\n     */\n    public getValueOrDefault(dflt?: T): T|undefined {\n        return this._value ?? dflt;\n    }\n\n    /**\n     * {@inheritdoc IResult.onSuccess}\n     */\n    public onSuccess<TN>(cb: SuccessContinuation<T, TN>): Result<TN> {\n        return cb(this.value);\n    }\n\n    /**\n     * {@inheritdoc IResult.onFailure}\n     */\n    public onFailure(_: FailureContinuation<T>): Result<T> {\n        return this;\n    }\n\n    /**\n     * {@inheritdoc IResult.withFailureDetail}\n     */\n    public withFailureDetail<TD>(_detail: TD): DetailedResult<T, TD> {\n        return succeedWithDetail(this.value);\n    }\n\n    /**\n     * {@inheritdoc IResult.withDetail}\n     */\n    public withDetail<TD>(detail: TD, successDetail?: TD): DetailedResult<T, TD> {\n        return succeedWithDetail(this.value, successDetail ?? detail);\n    }\n}\n\n/**\n * Reports a failed {@link IResult | result} from some operation, with an error message.\n * @public\n */\nexport class Failure<T> implements IResult<T> {\n    /**\n     * {@inheritdoc IResult.success}\n     */\n    public readonly success = false;\n\n    /**\n     * @internal\n     */\n    private readonly _message: string;\n\n    /**\n     * Constructs a {@link Failure} with the supplied message.\n     * @param message - Error message to be reported.\n     */\n    constructor(message: string) {\n        this._message = message;\n    }\n\n    /**\n     * Gets the error message associated with this error.\n     */\n    public get message(): string {\n        return this._message;\n    }\n\n    /**\n     * {@inheritdoc IResult.isSuccess}\n     */\n    public isSuccess(): this is Success<T> {\n        return false;\n    }\n\n    /**\n     * {@inheritdoc IResult.isFailure}\n     */\n    public isFailure(): this is Failure<T> {\n        return true;\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrThrow}\n     */\n    public getValueOrThrow(logger?: IResultLogger): never {\n        if (logger !== undefined) {\n            logger.error(this._message);\n        }\n        throw new Error(this._message);\n    }\n\n    /**\n     * {@inheritdoc IResult.getValueOrDefault}\n     */\n    public getValueOrDefault(dflt?: T): T|undefined {\n        return dflt;\n    }\n\n    /**\n     * {@inheritdoc IResult.onSuccess}\n     */\n    public onSuccess<TN>(_: SuccessContinuation<T, TN>): Result<TN> {\n        return new Failure(this.message);\n    }\n\n    /**\n     * {@inheritdoc IResult.onFailure}\n     */\n    public onFailure(cb: FailureContinuation<T>): Result<T> {\n        return cb(this.message);\n    }\n\n    /**\n     * {@inheritdoc IResult.withFailureDetail}\n     */\n    public withFailureDetail<TD>(detail: TD): DetailedResult<T, TD> {\n        return failWithDetail(this.message, detail);\n    }\n\n    /**\n     * {@inheritdoc IResult.withDetail}\n     */\n    public withDetail<TD>(detail: TD, _successDetail?: TD): DetailedResult<T, TD> {\n        return failWithDetail(this.message, detail);\n    }\n\n    /**\n     * Get a 'friendly' string representation of this object.\n     * @remarks\n     * The string representation of a {@link Failure} value is the error message.\n     * @returns A string representing this object.\n     */\n    public toString(): string {\n        return this.message;\n    }\n}\n\n/**\n * Returns {@link Success | Success<T>} with the supplied result value.\n * @param value - The successful result value to be returned\n * @public\n */\nexport function succeed<T>(value: T): Success<T> {\n    return new Success<T>(value);\n}\n\n/**\n * Returns {@link Failure | Failure<T>} with the supplied error message.\n * @param message - Error message to be returned.\n * @public\n */\nexport function fail<T>(message: string): Failure<T> {\n    return new Failure<T>(message);\n}\n\n/**\n * Callback to be called when a {@link DetailedResult} encounters success.\n * @remarks\n * A success callback can return a different result type than it receives, allowing\n * success results to chain through intermediate result types.\n * @public\n */\nexport type DetailedSuccessContinuation<T, TD, TN> = (value: T, detail?: TD) => DetailedResult<TN, TD>;\n\n/**\n * Callback to be called when a {@link DetailedResult} encounters a failure.\n * @remarks\n * A failure callback can change {@link Failure} to {@link Success} (e.g. by returning a default value)\n * or it can change or embellish the error message, but it cannot change the success return type.\n * @public\n */\nexport type DetailedFailureContinuation<T, TD> = (message: string, detail: TD) => DetailedResult<T, TD>;\n\n/**\n * A {@link DetailedSuccess} extends {@link Success} to report optional success details in\n * addition to the error message.\n * @public\n */\nexport class DetailedSuccess<T, TD> extends Success<T> {\n    /**\n     * @internal\n     */\n    protected _detail?: TD;\n\n    /**\n     * Constructs a new {@link DetailedSuccess | DetailedSuccess<T, TD>} with the supplied\n     * value and detail.\n     * @param value - The value to be returned.\n     * @param detail - An optional successful detail to be returned.  If omitted, detail\n     * will be `undefined`.\n     */\n    public constructor(value: T, detail?: TD) {\n        super(value);\n        this._detail = detail;\n    }\n\n    /**\n     * The success detail associated with this {@link DetailedSuccess}, or `undefined` if\n     * no detail was supplied.\n     */\n    public get detail(): TD|undefined {\n        return this._detail;\n    }\n\n    /**\n     * Reports that this {@link DetailedSuccess} is a success.\n     * @remarks\n     * Always true for {@link DetailedSuccess} but can be used as type guard\n     * to discriminate {@link DetailedSuccess} from {@link DetailedFailure} in\n     * a {@link DetailedResult}.\n     * @returns `true`\n     */\n    public isSuccess(): this is DetailedSuccess<T, TD> {\n        return true;\n    }\n\n    /**\n     * Invokes the supplied {@link DetailedSuccessContinuation | success callback} and propagates\n     * its returned {@link DetailedResult | DetailedResult<TN, TD>}.\n     * @remarks\n     * The success callback mutates the return type from `<T>` to `<TN>`.\n     * @param cb - The {@link DetailedSuccessContinuation | success callback} to be invoked.\n     * @returns The {@link DetailedResult | DetailedResult<T, TD>} returned by the success callback.\n     */\n    public onSuccess<TN>(cb: DetailedSuccessContinuation<T, TD, TN>): DetailedResult<TN, TD> {\n        return cb(this.value, this._detail);\n    }\n\n    /**\n     * Propagates this {@link DetailedSuccess}.\n     * @remarks\n     * Failure does not mutate return type so we can return this event directly.\n     * @param _cb - {@link DetailedFailureContinuation | Failure callback} to be called\n     * on a {@link DetailedResult} in case of failure (ignored).\n     * @returns `this`\n     */\n    public onFailure(_cb: DetailedFailureContinuation<T, TD>): DetailedResult<T, TD> {\n        return this;\n    }\n}\n\n/**\n * A {@link DetailedFailure} extends {@link Failure} to report optional failure details in\n * addition to the error message.\n * @public\n */\nexport class DetailedFailure<T, TD> extends Failure<T> {\n    /**\n     * @internal\n     */\n    protected _detail: TD;\n\n    /**\n     * Constructs a new {@link DetailedFailure | DetailedFailure<T, TD>} with the supplied\n     * message and detail.\n     * @param message - The message to be returned.\n     * @param detail - The error detail to be returned.\n     */\n    public constructor(message: string, detail: TD) {\n        super(message);\n        this._detail = detail;\n    }\n\n    /**\n     * The error detail associated with this {@link DetailedFailure}.\n     */\n    public get detail(): TD {\n        return this._detail;\n    }\n\n    /**\n     * Reports that this {@link DetailedFailure} is a failure.\n     * @remarks\n     * Always true for {@link DetailedFailure} but can be used as type guard\n     * to discriminate {@link DetailedSuccess} from {@link DetailedFailure} in\n     * a {@link DetailedResult}.\n     * @returns `true`\n     */\n    public isFailure(): this is DetailedFailure<T, TD> {\n        return true;\n    }\n\n    /**\n     * Propagates the error message and detail from this result.\n     * @remarks\n     * Mutates the success type as the success callback would have, but does not\n     * call the success callback.\n     * @param _cb - {@link DetailedSuccessContinuation | Success callback} to be called\n     * on a {@link DetailedResult} in case of success (ignored).\n     * @returns A new {@link DetailedFailure | DetailedFailure<TN, TD>} which contains\n     * the error message and detail from this one.\n     */\n    public onSuccess<TN>(_cb: DetailedSuccessContinuation<T, TD, TN>): DetailedResult<TN, TD> {\n        return new DetailedFailure<TN, TD>(this.message, this._detail);\n    }\n\n    /**\n     * Invokes the supplied {@link DetailedFailureContinuation | failure callback} and propagates\n     * its returned {@link DetailedResult | DetailedResult<T, TD>}.\n     * @param cb - The {@link DetailedFailureContinuation | failure callback} to be invoked.\n     * @returns The {@link DetailedResult | DetailedResult<T, TD>} returned by the failure callback.\n     */\n    public onFailure(cb: DetailedFailureContinuation<T, TD>): DetailedResult<T, TD> {\n        return cb(this.message, this._detail);\n    }\n}\n\n/**\n * Type inference to determine the result type `T` of a {@link DetailedResult | DetailedResult<T, TD>}.\n * @beta\n */\nexport type DetailedResult<T, TD> = DetailedSuccess<T, TD>|DetailedFailure<T, TD>;\n\n/**\n * Type inference to determine the detail type `TD` of a {@link DetailedResult | DetailedResult<T, TD>}.\n * @beta\n */\nexport type ResultDetailType<T> = T extends DetailedResult<unknown, infer TD> ? TD : never;\n\n/**\n * Returns {@link DetailedSuccess | DetailedSuccess<T, TD>} with a supplied value and optional\n * detail.\n * @param value - The value of type `<T>` to be returned.\n * @param detail - An optional detail of type `<TD>` to be returned.\n * @returns A {@link DetailedSuccess | DetailedSuccess<T, TD>} with the supplied value\n * and detail, if supplied.\n * @public\n */\nexport function succeedWithDetail<T, TD>(value: T, detail?: TD): DetailedSuccess<T, TD> {\n    return new DetailedSuccess<T, TD>(value, detail);\n}\n\n/**\n * Returns {@link DetailedFailure | DetailedFailure<T, TD>} with a supplied error message and detail.\n * @param message - The error message to be returned.\n * @param detail - The event detail to be returned.\n * @returns An {@link DetailedFailure | DetailedFailure<T, TD>} with the supplied error\n * message and detail.\n * @public\n */\nexport function failWithDetail<T, TD>(message: string, detail: TD): DetailedFailure<T, TD> {\n    return new DetailedFailure<T, TD>(message, detail);\n}\n\n/**\n * Propagates a {@link Success} or {@link Failure} {@link Result}, adding supplied\n * event details as appropriate.\n * @param result - The {@link Result} to be propagated.\n * @param detail - The event detail (type `<TD>`) to be added to the {@link Result | result}.\n * @param successDetail - An optional distinct event detail to be added to {@link Success} results.  If `successDetail`\n * is omitted or `undefined`, then `detail` will be applied to {@link Success} results.\n * @returns A new {@link DetailedResult | DetailedResult<T, TD>} with the success value or error\n * message from the original `result` but with the specified detail added.\n * @public\n */\nexport function propagateWithDetail<T, TD>(result: Result<T>, detail: TD, successDetail?: TD): DetailedResult<T, TD> {\n    return result.isSuccess()\n        ? succeedWithDetail(result.value, successDetail ?? detail)\n        : failWithDetail(result.message, detail);\n}\n\n/**\n * Wraps a function which might throw to convert exception results\n * to {@link Failure}.\n * @param func - The function to be captured.\n * @returns Returns {@link Success} with a value of type `<T>` on\n * success , or {@link Failure} with the thrown error message if\n * `func` throws an `Error`.\n * @public\n */\nexport function captureResult<T>(func: () => T): Result<T> {\n    try {\n        return succeed(func());\n    }\n    catch (err) {\n        return fail((err as Error).message);\n    }\n}\n\n/**\n * Aggregates successful result values from a collection of {@link Result | Result<T>}.\n * @param results - The collection of {@link Result | Result<T>} to be mapped.\n * @returns  If all {@link Result | results} are successful, returns {@link Success} with an\n * array containing all returned values.  If any {@link Result | results} failed, returns\n * {@link Failure} with a concatenated summary of all error messages.\n * @public\n */\nexport function mapResults<T>(results: Iterable<Result<T>>): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else {\n            errors.push(result.message);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates successful results from a collection of {@link DetailedResult | DetailedResult<T, TD>},\n * optionally ignoring certain error details.\n * @param results - The collection of {@link DetailedResult | DetailedResult<T, TD>} to be mapped.\n * @param ignore - An array of error detail values (of type `<TD>`) that should be ignored.\n * @returns {@link Success} with an array containing all successful results if all results either\n * succeeded or returned error details listed in `ignore`.  If any results failed with details\n * that cannot be ignored, returns {@link Failure} with an concatenated summary of all non-ignorable\n * error messages.\n * @public\n */\nexport function mapDetailedResults<T, TD>(results: Iterable<DetailedResult<T, TD>>, ignore: TD[]): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else if (!ignore.includes(result.detail)) {\n            errors.push(result.message);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates successful results from a a collection of {@link Result | Result<T>}.\n * @param results - An `Iterable` of {@link Result | Result<T>} from which success\n * results are to be aggregated.\n * @returns {@link Success} with an array of `<T>` if any results were successful. If\n * all {@link Result | results} failed, returns {@link Failure} with a concatenated\n * summary of all error messages.\n * @public\n */\nexport function mapSuccess<T>(results: Iterable<Result<T>>): Result<T[]> {\n    const errors: string[] = [];\n    const elements: T[] = [];\n\n    for (const result of results) {\n        if (result.isSuccess()) {\n            elements.push(result.value);\n        }\n        else {\n            errors.push(result.message);\n        }\n    }\n\n    if ((elements.length === 0) && (errors.length > 0)) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(elements);\n}\n\n/**\n * Aggregates error messages from a collection of {@link Result | Result<T>}.\n * @param results - An iterable collection of {@link Result | Result<T>} for which\n * error messages are aggregated.\n * @returns An array of strings consisting of all error messages returned by\n * {@link Result | results} in the source collection. Ignores {@link Success}\n * results and returns an empty array if there were no errors.\n * @public\n */\nexport function mapFailures<T>(results: Iterable<Result<T>>): string[] {\n    const errors: string[] = [];\n    for (const result of results) {\n        if (result.isFailure()) {\n            errors.push(result.message);\n        }\n    }\n    return errors;\n}\n\n/**\n * Determines if an iterable collection of {@link Result | Result<T>} were all successful.\n * @param results - The collection of {@link Result | Result<T>} to be tested.\n * @returns Returns {@link Success} with `true` if all {@link Result | results} are successful.\n * If any are unsuccessful, returns {@link Failure} with a concatenated summary the error\n * messages from all failed elements.\n * @public\n */\nexport function allSucceed<T>(results: Iterable<Result<unknown>>, successValue: T): Result<T> {\n    const errors: string[] = [];\n\n    // istanbul ignore else\n    if (results !== undefined) {\n        for (const result of results) {\n            if (result.isFailure()) {\n                errors.push(result.message);\n            }\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(successValue);\n}\n\n/**\n * String-keyed record of initialization functions to be passed to {@link populateObject}.\n * @public\n */\nexport type FieldInitializers<T> = { [ key in keyof T ]: (state: Partial<T>) => Result<T[key]> };\n\n/**\n * Populates an an object based on a prototype full of field initializers that return {@link Result | Result<T[key]>}.\n * Returns {@link Success} with the populated object if all initializers succeed, or {@link Failure} with a\n * concatenated list of all error messages.\n * @param initializers - An object with the shape of the target but with initializer functions for\n * each property.\n * @public\n */\nexport function populateObject<T>(initializers: FieldInitializers<T>, order?: (keyof T)[]): Result<T> {\n    const state = {} as { [key in keyof T]: T[key] };\n    const errors: string[] = [];\n    const keys: (keyof T)[] = Array.from(order ?? []);\n    const foundKeys = new Set<keyof T>(order);\n\n    // start with the supplied order then append anything else we find\n    for (const key in initializers) {\n        if (!foundKeys.has(key)) {\n            keys.push(key);\n            foundKeys.add(key);\n        }\n    }\n\n    for (const key of keys) {\n        if (initializers[key]) {\n            const result = initializers[key](state);\n            if (result.isSuccess()) {\n                state[key] = result.value;\n            }\n            else {\n                errors.push(result.message);\n            }\n        }\n        else {\n            errors.push(`populateObject: Key ${String(key)} is present but has no initializer`);\n        }\n    }\n\n    if (errors.length > 0) {\n        return fail(errors.join('\\n'));\n    }\n    return succeed(state as T);\n}\n"]} |
@@ -37,3 +37,3 @@ import { Result } from './result'; | ||
*/ | ||
declare type KeyedThingFactory<TS, TD, TK extends string = string> = (key: TK, thing: TS) => Result<TD>; | ||
type KeyedThingFactory<TS, TD, TK extends string = string> = (key: TK, thing: TS) => Result<TD>; | ||
/** | ||
@@ -40,0 +40,0 @@ * Applies a factory method to convert a `Record<TK, TS>` into a `Map<TK, TD>`. |
@@ -7,3 +7,3 @@ import { Failure } from '../result'; | ||
*/ | ||
export declare type BooleanValidatorConstructorParams<TC = unknown> = GenericValidatorConstructorParams<boolean, TC>; | ||
export type BooleanValidatorConstructorParams<TC = unknown> = GenericValidatorConstructorParams<boolean, TC>; | ||
/** | ||
@@ -10,0 +10,0 @@ * An in-place {@link Validation.Validator | Validator} for `boolean` values. |
@@ -11,3 +11,3 @@ import { Constraint, Validator, ValidatorOptions } from './validator'; | ||
*/ | ||
export declare type ValidatorFunc<T, TC> = (from: unknown, context?: TC) => boolean | Failure<T>; | ||
export type ValidatorFunc<T, TC> = (from: unknown, context?: TC) => boolean | Failure<T>; | ||
/** | ||
@@ -14,0 +14,0 @@ * Options used to initialize a {@link Validation.Base.GenericValidator | GenericValidator}. |
@@ -7,3 +7,3 @@ import { Failure } from '../result'; | ||
*/ | ||
export declare type NumberValidatorConstructorParams<T extends number = number, TC = unknown> = GenericValidatorConstructorParams<T, TC>; | ||
export type NumberValidatorConstructorParams<T extends number = number, TC = unknown> = GenericValidatorConstructorParams<T, TC>; | ||
/** | ||
@@ -10,0 +10,0 @@ * An in-place {@link Validation.Validator | Validator} for `number` values. |
@@ -8,3 +8,3 @@ import { Failure } from '../result'; | ||
*/ | ||
export declare type FieldValidators<T, TC = unknown> = { | ||
export type FieldValidators<T, TC = unknown> = { | ||
[key in keyof T]: Validator<T[key], TC>; | ||
@@ -11,0 +11,0 @@ }; |
@@ -7,3 +7,3 @@ import { Failure } from '../result'; | ||
*/ | ||
export declare type StringValidatorConstructorParams<T extends string = string, TC = unknown> = GenericValidatorConstructorParams<T, TC>; | ||
export type StringValidatorConstructorParams<T extends string = string, TC = unknown> = GenericValidatorConstructorParams<T, TC>; | ||
/** | ||
@@ -10,0 +10,0 @@ * An in-place {@link Validation.Validator | Validator} for `string` values. |
@@ -14,3 +14,3 @@ /** | ||
*/ | ||
export declare type ConstraintTrait = FunctionConstraintTrait; | ||
export type ConstraintTrait = FunctionConstraintTrait; | ||
/** | ||
@@ -17,0 +17,0 @@ * Interface describing the supported validator traits. |
@@ -18,3 +18,3 @@ import { ConstraintTrait, ValidatorTraits } from './traits'; | ||
*/ | ||
export declare type Constraint<T> = (val: T) => boolean | Failure<T>; | ||
export type Constraint<T> = (val: T) => boolean | Failure<T>; | ||
/** | ||
@@ -21,0 +21,0 @@ * In-place validation that a supplied unknown matches some |
import { GenericValidator, GenericValidatorConstructorParams } from './genericValidator'; | ||
import { Failure } from '../result'; | ||
export declare type ValidatorBaseConstructorParams<T, TC> = Omit<GenericValidatorConstructorParams<T, TC>, 'validator'>; | ||
export type ValidatorBaseConstructorParams<T, TC> = Omit<GenericValidatorConstructorParams<T, TC>, 'validator'>; | ||
/** | ||
@@ -5,0 +5,0 @@ * Abstract base helper class for specific validator implementations |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
642540
21
5869
+ Addedcsv-parse@5.6.0(transitive)
+ Addedluxon@3.5.0(transitive)
- Removedcsv-parse@4.16.3(transitive)
- Removedluxon@2.5.2(transitive)
Updatedcsv-parse@^5.3.3
Updatedluxon@^3.1.1