parser

package
v0.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 4, 2023 License: MIT Imports: 18 Imported by: 0

README

parser

-- import "github.com/dop251/goja/parser"

Package parser implements a parser for JavaScript. Borrowed from https://github.com/robertkrimen/otto/tree/master/parser

import (
    "github.com/dop251/goja/parser"
)

Parse and return an AST

filename := "" // A filename is optional
src := `
    // Sample xyzzy example
    (function(){
        if (3.14159 > 0) {
            console.log("Hello, World.");
            return;
        }

        var xyzzy = NaN;
        console.log("Nothing happens.");
        return xyzzy;
    })();
`

// Parse some JavaScript, yielding a *ast.Program and/or an ErrorList
program, err := parser.ParseFile(nil, filename, src, 0)
Warning

The parser and AST interfaces are still works-in-progress (particularly where node types are concerned) and may change in the future.

Usage

func ParseFile
func ParseFile(fileSet *file.FileSet, filename string, src interface{}, mode Mode) (*ast.Program, error)

ParseFile parses the source code of a single JavaScript/ECMAScript source file and returns the corresponding ast.Program node.

If fileSet == nil, ParseFile parses source without a FileSet. If fileSet != nil, ParseFile first adds filename and src to fileSet.

The filename argument is optional and is used for labelling errors, etc.

src may be a string, a byte slice, a bytes.Buffer, or an io.Reader, but it MUST always be in UTF-8.

// Parse some JavaScript, yielding a *ast.Program and/or an ErrorList
program, err := parser.ParseFile(nil, "", `if (abc > 1) {}`, 0)
func ParseFunction
func ParseFunction(parameterList, body string) (*ast.FunctionLiteral, error)

ParseFunction parses a given parameter list and body as a function and returns the corresponding ast.FunctionLiteral node.

The parameter list, if any, should be a comma-separated list of identifiers.

func ReadSource
func ReadSource(filename string, src interface{}) ([]byte, error)
func TransformRegExp
func TransformRegExp(pattern string) (string, error)

TransformRegExp transforms a JavaScript pattern into a Go "regexp" pattern.

re2 (Go) cannot do backtracking, so the presence of a lookahead (?=) (?!) or backreference (\1, \2, ...) will cause an error.

re2 (Go) has a different definition for \s: [\t\n\f\r ]. The JavaScript definition, on the other hand, also includes \v, Unicode "Separator, Space", etc.

If the pattern is invalid (not valid even in JavaScript), then this function returns the empty string and an error.

If the pattern is valid, but incompatible (contains a lookahead or backreference), then this function returns the transformation (a non-empty string) AND an error.

type Error
type Error struct {
	Position file.Position
	Message  string
}

An Error represents a parsing error. It includes the position where the error occurred and a message/description.

func (Error) Error
func (self Error) Error() string
type ErrorList
type ErrorList []*Error

ErrorList is a list of *Errors.

func (*ErrorList) Add
func (self *ErrorList) Add(position file.Position, msg string)

Add adds an Error with given position and message to an ErrorList.

func (ErrorList) Err
func (self ErrorList) Err() error

Err returns an error equivalent to this ErrorList. If the list is empty, Err returns nil.

func (ErrorList) Error
func (self ErrorList) Error() string

Error implements the Error interface.

func (ErrorList) Len
func (self ErrorList) Len() int
func (ErrorList) Less
func (self ErrorList) Less(i, j int) bool
func (*ErrorList) Reset
func (self *ErrorList) Reset()

Reset resets an ErrorList to no errors.

func (ErrorList) Sort
func (self ErrorList) Sort()
func (ErrorList) Swap
func (self ErrorList) Swap(i, j int)
type Mode
type Mode uint

A Mode value is a set of flags (or 0). They control optional parser functionality.

-- godocdown http://github.com/robertkrimen/godocdown

Documentation

Overview

Package parser implements a parser for JavaScript.

import (
    "github.com/dop251/goja/parser"
)

Parse and return an AST

filename := "" // A filename is optional
src := `
    // Sample xyzzy example
    (function(){
        if (3.14159 > 0) {
            console.log("Hello, World.");
            return;
        }

        var xyzzy = NaN;
        console.log("Nothing happens.");
        return xyzzy;
    })();
`

// Parse some JavaScript, yielding a *ast.Program and/or an ErrorList
program, err := parser.ParseFile(nil, filename, src, 0)

Warning

The parser and AST interfaces are still works-in-progress (particularly where node types are concerned) and may change in the future.

Index

Constants

View Source
const (
	WhitespaceChars = " \f\n\r\t\v\u00a0\u1680\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u2028\u2029\u202f\u205f\u3000\ufeff"
	Re2Dot          = "[^\r\n\u2028\u2029]"
)

Variables

This section is empty.

Functions

func IsIdentifier

func IsIdentifier(s string) bool

func ParseFile

func ParseFile(fileSet *file.FileSet, filename string, src interface{}, mode Mode, options ...Option) (*ast.Program, error)

ParseFile parses the source code of a single JavaScript/ECMAScript source file and returns the corresponding ast.Program node.

If fileSet == nil, ParseFile parses source without a FileSet. If fileSet != nil, ParseFile first adds filename and src to fileSet.

The filename argument is optional and is used for labelling errors, etc.

src may be a string, a byte slice, a bytes.Buffer, or an io.Reader, but it MUST always be in UTF-8.

// Parse some JavaScript, yielding a *ast.Program and/or an ErrorList
program, err := parser.ParseFile(nil, "", `if (abc > 1) {}`, 0)

func ParseFunction

func ParseFunction(parameterList, body string, options ...Option) (*ast.FunctionLiteral, error)

ParseFunction parses a given parameter list and body as a function and returns the corresponding ast.FunctionLiteral node.

The parameter list, if any, should be a comma-separated list of identifiers.

func ReadSource

func ReadSource(filename string, src interface{}) ([]byte, error)

func TransformRegExp

func TransformRegExp(pattern string) (transformed string, err error)

TransformRegExp transforms a JavaScript pattern into a Go "regexp" pattern.

re2 (Go) cannot do backtracking, so the presence of a lookahead (?=) (?!) or backreference (\1, \2, ...) will cause an error.

re2 (Go) has a different definition for \s: [\t\n\f\r ]. The JavaScript definition, on the other hand, also includes \v, Unicode "Separator, Space", etc.

If the pattern is valid, but incompatible (contains a lookahead or backreference), then this function returns an empty string an error of type RegexpErrorIncompatible.

If the pattern is invalid (not valid even in JavaScript), then this function returns an empty string and a generic error.

func WithDisableSourceMaps

func WithDisableSourceMaps(opts *options)

WithDisableSourceMaps is an option to disable source maps support. May save a bit of time when source maps are not in use.

Types

type Error

type Error struct {
	Position file.Position
	Message  string
}

An Error represents a parsing error. It includes the position where the error occurred and a message/description.

func (Error) Error

func (self Error) Error() string

type ErrorList

type ErrorList []*Error

ErrorList is a list of *Errors.

func (*ErrorList) Add

func (self *ErrorList) Add(position file.Position, msg string)

Add adds an Error with given position and message to an ErrorList.

func (ErrorList) Err

func (self ErrorList) Err() error

Err returns an error equivalent to this ErrorList. If the list is empty, Err returns nil.

func (ErrorList) Error

func (self ErrorList) Error() string

Error implements the Error interface.

func (ErrorList) Len

func (self ErrorList) Len() int

func (ErrorList) Less

func (self ErrorList) Less(i, j int) bool

func (*ErrorList) Reset

func (self *ErrorList) Reset()

Reset resets an ErrorList to no errors.

func (ErrorList) Sort

func (self ErrorList) Sort()

func (ErrorList) Swap

func (self ErrorList) Swap(i, j int)

type Mode

type Mode uint

A Mode value is a set of flags (or 0). They control optional parser functionality.

const (
	IgnoreRegExpErrors Mode = 1 << iota // Ignore RegExp compatibility errors (allow backtracking)
)

type Option

type Option func(*options)

Option represents one of the options for the parser to use in the Parse methods. Currently supported are: WithDisableSourceMaps and WithSourceMapLoader.

func WithSourceMapLoader

func WithSourceMapLoader(loader func(path string) ([]byte, error)) Option

WithSourceMapLoader is an option to set a custom source map loader. The loader will be given a path or a URL from the sourceMappingURL. If sourceMappingURL is not absolute it is resolved relatively to the name of the file being parsed. Any error returned by the loader will fail the parsing. Note that setting this to nil does not disable source map support, there is a default loader which reads from the filesystem. Use WithDisableSourceMaps to disable source map support.

type RegexpErrorIncompatible

type RegexpErrorIncompatible struct {
	// contains filtered or unexported fields
}

func (RegexpErrorIncompatible) Error

func (s RegexpErrorIncompatible) Error() string

type RegexpSyntaxError

type RegexpSyntaxError struct {
	// contains filtered or unexported fields
}

func (RegexpSyntaxError) Error

func (s RegexpSyntaxError) Error() string

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL