deno.land / std@0.224.0 / yaml / schema.ts
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110// Ported from js-yaml v3.13.1:// https://github.com/nodeca/js-yaml/commit/665aadda42349dcae869f12040d9b10ef18d12da// Copyright 2011-2015 by Vitaly Puzrin. All rights reserved. MIT license.// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.// This module is browser compatible.
import { YAMLError } from "./_error.ts";import type { KindType, Type } from "./type.ts";import type { Any, ArrayObject } from "./_utils.ts";
function compileList( schema: Schema, name: "implicit" | "explicit", result: Type[],): Type[] { const exclude: number[] = [];
for (const includedSchema of schema.include) { result = compileList(includedSchema, name, result); }
for (const currentType of schema[name]) { for (const [previousIndex, previousType] of result.entries()) { if ( previousType.tag === currentType.tag && previousType.kind === currentType.kind ) { exclude.push(previousIndex); } }
result.push(currentType); }
return result.filter((_type, index): unknown => !exclude.includes(index));}
export type TypeMap = { [k in KindType | "fallback"]: ArrayObject<Type> };function compileMap(...typesList: Type[][]): TypeMap { const result: TypeMap = { fallback: {}, mapping: {}, scalar: {}, sequence: {}, };
for (const types of typesList) { for (const type of types) { if (type.kind !== null) { result[type.kind][type.tag] = result["fallback"][type.tag] = type; } } } return result;}
export class Schema implements SchemaDefinition { public static SCHEMA_DEFAULT?: Schema;
public implicit: Type[]; public explicit: Type[]; public include: Schema[];
public compiledImplicit: Type[]; public compiledExplicit: Type[]; public compiledTypeMap: TypeMap;
constructor(definition: SchemaDefinition) { this.explicit = definition.explicit || []; this.implicit = definition.implicit || []; this.include = definition.include || [];
for (const type of this.implicit) { if (type.loadKind && type.loadKind !== "scalar") { throw new YAMLError( "There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.", ); } }
this.compiledImplicit = compileList(this, "implicit", []); this.compiledExplicit = compileList(this, "explicit", []); this.compiledTypeMap = compileMap( this.compiledImplicit, this.compiledExplicit, ); }
/* Returns a new extended schema from current schema */ public extend(definition: SchemaDefinition): Schema { return new Schema({ implicit: [ ...new Set([...this.implicit, ...(definition?.implicit ?? [])]), ], explicit: [ ...new Set([...this.explicit, ...(definition?.explicit ?? [])]), ], include: [...new Set([...this.include, ...(definition?.include ?? [])])], }); }
public static create() {}}
export interface SchemaDefinition { implicit?: Any[]; explicit?: Type[]; include?: Schema[];}
Version Info