1 | import { CreateNodeContext } from '../doc/createNode.js';
|
---|
2 | import type { BlockSequence, FlowCollection } from '../parse/cst.js';
|
---|
3 | import type { Schema } from '../schema/Schema.js';
|
---|
4 | import type { StringifyContext } from '../stringify/stringify.js';
|
---|
5 | import { Collection } from './Collection.js';
|
---|
6 | import type { ParsedNode, Range } from './Node.js';
|
---|
7 | import type { Pair } from './Pair.js';
|
---|
8 | import { Scalar } from './Scalar.js';
|
---|
9 | import { ToJSContext } from './toJS.js';
|
---|
10 | export declare namespace YAMLSeq {
|
---|
11 | interface Parsed<T extends ParsedNode | Pair<ParsedNode, ParsedNode | null> = ParsedNode> extends YAMLSeq<T> {
|
---|
12 | items: T[];
|
---|
13 | range: Range;
|
---|
14 | srcToken?: BlockSequence | FlowCollection;
|
---|
15 | }
|
---|
16 | }
|
---|
17 | export declare class YAMLSeq<T = unknown> extends Collection {
|
---|
18 | static get tagName(): 'tag:yaml.org,2002:seq';
|
---|
19 | items: T[];
|
---|
20 | constructor(schema?: Schema);
|
---|
21 | add(value: T): void;
|
---|
22 | /**
|
---|
23 | * Removes a value from the collection.
|
---|
24 | *
|
---|
25 | * `key` must contain a representation of an integer for this to succeed.
|
---|
26 | * It may be wrapped in a `Scalar`.
|
---|
27 | *
|
---|
28 | * @returns `true` if the item was found and removed.
|
---|
29 | */
|
---|
30 | delete(key: unknown): boolean;
|
---|
31 | /**
|
---|
32 | * Returns item at `key`, or `undefined` if not found. By default unwraps
|
---|
33 | * scalar values from their surrounding node; to disable set `keepScalar` to
|
---|
34 | * `true` (collections are always returned intact).
|
---|
35 | *
|
---|
36 | * `key` must contain a representation of an integer for this to succeed.
|
---|
37 | * It may be wrapped in a `Scalar`.
|
---|
38 | */
|
---|
39 | get(key: unknown, keepScalar: true): Scalar<T> | undefined;
|
---|
40 | get(key: unknown, keepScalar?: false): T | undefined;
|
---|
41 | get(key: unknown, keepScalar?: boolean): T | Scalar<T> | undefined;
|
---|
42 | /**
|
---|
43 | * Checks if the collection includes a value with the key `key`.
|
---|
44 | *
|
---|
45 | * `key` must contain a representation of an integer for this to succeed.
|
---|
46 | * It may be wrapped in a `Scalar`.
|
---|
47 | */
|
---|
48 | has(key: unknown): boolean;
|
---|
49 | /**
|
---|
50 | * Sets a value in this collection. For `!!set`, `value` needs to be a
|
---|
51 | * boolean to add/remove the item from the set.
|
---|
52 | *
|
---|
53 | * If `key` does not contain a representation of an integer, this will throw.
|
---|
54 | * It may be wrapped in a `Scalar`.
|
---|
55 | */
|
---|
56 | set(key: unknown, value: T): void;
|
---|
57 | toJSON(_?: unknown, ctx?: ToJSContext): unknown[];
|
---|
58 | toString(ctx?: StringifyContext, onComment?: () => void, onChompKeep?: () => void): string;
|
---|
59 | static from(schema: Schema, obj: unknown, ctx: CreateNodeContext): YAMLSeq<unknown>;
|
---|
60 | }
|
---|