Skip to content

Latest commit

 

History

History
539 lines (270 loc) · 11.8 KB

ArrayParser.md

File metadata and controls

539 lines (270 loc) · 11.8 KB

tsukikoDocs


tsukiko / ArrayParser

Class: ArrayParser<S>

Parser for array values.

Extends

Type Parameters

S extends Parser<unknown> = NeverParser

The type of the array elements parser.

Constructors

new ArrayParser()

new ArrayParser<S>(type): ArrayParser<S>

Creates a new instance of ArrayParser.

Parameters

type: S

The parser for array elements.

Returns

ArrayParser<S>

Overrides

Parser.constructor

Defined in

src/parsers/array.ts:43

Properties

defaultValue?

protected optional defaultValue: ParserInfer<S>[]

Inherited from

Parser.defaultValue

Defined in

src/parser.ts:49


isOptional

protected isOptional: boolean = false

Inherited from

Parser.isOptional

Defined in

src/parser.ts:44


langType

protected langType: langType = DEFAULT_LANG

Inherited from

Parser.langType

Defined in

src/utils/lang.ts:6


rules

protected rules: ParserFunction[]

Overrides

Parser.rules

Defined in

src/parsers/array.ts:16

Methods

check()

check(input): input is ParserInfer<S>[]

Checks if the input is valid according to the parser's rules.

Parameters

input: unknown

The input to check.

Returns

input is ParserInfer<S>[]

True if the input is valid, false otherwise.

Inherited from

Parser.check

Defined in

src/parser.ts:99


default()

default(value): Parser<ParserInfer<S>[]>

Sets a default value for the parser.

Parameters

value: ParserInfer<S>[]

The default value.

Returns

Parser<ParserInfer<S>[]>

The current Parser instance.

Inherited from

Parser.default

Defined in

src/parser.ts:118


defaultHandle()

protected defaultHandle(input): ParserInfer<S>[]

Parameters

input: ParserInfer<S>[]

Returns

ParserInfer<S>[]

Inherited from

Parser.defaultHandle

Defined in

src/parser.ts:34


describe()

describe(description): ArrayParser<S>

Sets a description for the parser.

Parameters

description: string

The description to set.

Returns

ArrayParser<S>

The current Parser instance.

Inherited from

Parser.describe

Defined in

src/parser.ts:138


empty()

empty(): ArrayParser<S>

Configures the parser to allow undefined but not null.

Returns

ArrayParser<S>

The current Parser instance.

Inherited from

Parser.empty

Defined in

src/parser.ts:128


error()

protected error(lang, data?): TsuError

Parameters

lang: "not_string" | "not_a_email" | "not_a_domain" | "not_a_url" | "illegal_match_string" | "illegal_starts_with" | "illegal_ends_with" | "too_long" | "too_short" | "not_number" | "not_integer_number" | "not_odd_number" | "not_even_number" | "not_natural_number" | "not_positive_number" | "not_negative_number" | "not_percentage" | "too_bigger" | "too_bigger_has" | "too_smaller" | "too_smaller_has" | "not_multiple_number" | "is_a_NaN" | "not_boolean" | "not_true" | "not_false" | "not_null" | "not_undefined" | "not_never" | "not_an_array" | "array_error" | "too_many_items" | "too_few_items" | "not_a_tuple" | "illegal_tuple_length" | "tuple_error" | "not_an_object" | "object_is_null" | "object_is_an_array" | "object_not_instance_of_constructor" | "object_keys_too_many" | "object_keys_too_few" | "object_error" | "object_key_error" | "intersection_error" | "union_error" | "literal_only" | "literal_number_error" | "literal_string_error" | "literal_boolean_error" | "custom_error" | "not_a_function" | "not_a_constructor" | "not_an_async_function" | "not_a_generator_function" | "not_an_async_generator_function" | "not_an_arrow_function" | "function_args_count_mismatch" | "function_name_mismatch" | "not_a_class" | "class_args_count_mismatch" | "class_name_mismatch" | "class_prototype_error"

data?

Returns

TsuError

Inherited from

Parser.error

Defined in

src/parser.ts:39


lang()

lang(value): ArrayParser<S>

Parameters

value: langType = DEFAULT_LANG

Returns

ArrayParser<S>

Inherited from

Parser.lang

Defined in

src/utils/lang.ts:8


max()

max(value): ArrayParser<S>

Sets the maximum number of items allowed in the array.

Parameters

value: number

The maximum number of items.

Returns

ArrayParser<S>

The current ArrayParser instance.

Defined in

src/parsers/array.ts:54


min()

min(value): ArrayParser<S>

Sets the minimum number of items required in the array.

Parameters

value: number

The minimum number of items.

Returns

ArrayParser<S>

The current ArrayParser instance.

Defined in

src/parsers/array.ts:65


optional()

optional(): Parser<undefined | ParserInfer<S>[]>

Makes the parser optional.

Returns

Parser<undefined | ParserInfer<S>[]>

The current Parser instance.

Inherited from

Parser.optional

Defined in

src/parser.ts:107


parse()

parse(input): ParserInfer<S>[]

Parses the input and returns the result.

Parameters

input: unknown

The input to parse.

Returns

ParserInfer<S>[]

The parsed result.

Throws

If parsing fails.

Inherited from

Parser.parse

Defined in

src/parser.ts:61


parseAsync()

parseAsync(input): Promise<unknown>

Asynchronously parses the input.

Parameters

input: unknown

The input to parse.

Returns

Promise<unknown>

A promise that resolves with the parsed result or rejects with an error.

Inherited from

Parser.parseAsync

Defined in

src/parser.ts:86


parseSafe()

parseSafe(input): ParserSafeReturn<ParserInfer<S>[]>

Safely parses the input and returns a result object.

Parameters

input: unknown

The input to parse.

Returns

ParserSafeReturn<ParserInfer<S>[]>

An object containing the parsing result or error.

Inherited from

Parser.parseSafe

Defined in

src/parser.ts:72


range()

range(min, max): ArrayParser<S>

Sets both the minimum and maximum number of items allowed in the array.

Parameters

min: number

The minimum number of items.

max: number

The maximum number of items.

Returns

ArrayParser<S>

The current ArrayParser instance.

Defined in

src/parsers/array.ts:77


schema()

schema(bringSchema): JsonSchema

Generates a JSON schema for the parser.

Parameters

bringSchema: boolean = true

Whether to include the $schema property. Defaults to true.

Returns

JsonSchema

The generated JSON schema.

Inherited from

Parser.schema

Defined in

src/parser.ts:158


setMeta()

protected setMeta(metadata): void

Parameters

metadata: Partial<SchemaMetadata>

Returns

void

Inherited from

Parser.setMeta

Defined in

src/parser.ts:51


title()

title(title): ArrayParser<S>

Sets a title for the parser.

Parameters

title: string

The title to set.

Returns

ArrayParser<S>

The current Parser instance.

Inherited from

Parser.title

Defined in

src/parser.ts:148