Socket
Socket
Sign inDemoInstall

yaml-ast-parser

Package Overview
Dependencies
0
Maintainers
2
Versions
26
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    yaml-ast-parser

[![Build Status](https://travis-ci.org/mulesoft-labs/yaml-ast-parser.svg?branch=master)](https://travis-ci.org/mulesoft-labs/yaml-ast-parser)


Version published
Maintainers
2
Install size
409 kB
Created

Package description

What is yaml-ast-parser?

The yaml-ast-parser npm package is a tool used for parsing YAML documents into an abstract syntax tree (AST). This allows developers to analyze and manipulate YAML data programmatically, making it useful for tasks such as configuration file processing, data validation, and transformation.

What are yaml-ast-parser's main functionalities?

Parsing YAML to AST

This feature allows the conversion of a YAML string into an AST structure. The code sample demonstrates how to parse a simple YAML text into an AST using yaml-ast-parser, which can then be traversed or manipulated according to the needs of the application.

const yamlAstParser = require('yaml-ast-parser');
const yamlText = 'a: 1\nb: 2\nc:\n  - 3\n  - 4';
const ast = yamlAstParser.load(yamlText);
console.log(ast);

Error Reporting

This feature is useful for error handling when parsing YAML. The code sample shows how to catch and report errors that occur during the parsing process, which is essential for debugging and ensuring data integrity.

const yamlAstParser = require('yaml-ast-parser');
const invalidYaml = 'a: 1\nb: \nc: 2';
try {
  yamlAstParser.load(invalidYaml);
} catch (error) {
  console.error('Parsing error:', error);
}

Other packages similar to yaml-ast-parser

Readme

Source

yaml-ast-parser

Build Status

This is a fork of JS-YAML which supports parsing of YAML into AST.

In additional to parsing YAML to AST, it has following features:

  • restoration after the errors and reporting errors as a part of AST nodes.
  • built-in support for !include tag used in RAML

Usage

The type information below is relevant when using TypeScript, if using from JavaScript only the field/method information is relevant.

load method can be used to load the tree and returns a YAMLNode.

YAMLNode

YAMLNode class is an ancestor for all node kinds. It's kind field determine node kind, one of Kind enum:

  • SCALAR, MAPPING, MAP, SEQ, ANCHOR_REF or INCLUDE_REF.

After node kind is determined, it can be cast to one of the YAMLNode descendants types:

  • YAMLScalar, YAMLMapping, YamlMap, YAMLSequence or YAMLAnchorReference.
classimportant members
YAMLNodestartPosition and endPosition provide node range.
YAMLScalarstring value field
YAMLMappingYAMLScalar key and YAMLNode value fields
YAMLSequenceYAMLNode[] items field
YamlMapYAMLMapping[] mappings field
YAMLAnchorReferencestring referencesAnchor and YAMLNode value

YAMLScalar

Scalars are one of the three main node types defined by YAML and are effectively leaf nodes.

There are many factors that can influence the type of datum represent in scalar node (context, schema, tag, etc.).

To help inspection of a YAMLScalar to determine its datatype when a document uses the Core Schema, you can pass the YAMLScalar to the determineScalarType function. It will return an enum value indicating null, bool, int, float, or string.

Once you know the type, there are also some helper functions to help read the value by passing them the string, value: parseYamlBoolean, parseYamlFloat, and parseYamlInteger.

Keywords

FAQs

Last updated on 04 Dec 2017

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc