2.2.34 • Published 2 years ago

@zitterorg/ipsam-officia v2.2.34

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

@zitterorg/ipsam-officia

npm version Downloads/month Build Status codecov

A regular expression parser for ECMAScript.

💿 Installation

$ npm install @zitterorg/ipsam-officia
  • require Node@^12.0.0 || ^14.0.0 || >=16.0.0.

📖 Usage

import {
    AST,
    RegExpParser,
    RegExpValidator,
    RegExpVisitor,
    parseRegExpLiteral,
    validateRegExpLiteral,
    visitRegExpAST
} from "@zitterorg/ipsam-officia"

parseRegExpLiteral(source, options?)

Parse a given regular expression literal then make AST object.

This is equivalent to new RegExpParser(options).parseLiteral(source).

  • Parameters:
    • source (string | RegExp) The source code to parse.
    • options? (RegExpParser.Options) The options to parse.
  • Return:
    • The AST of the regular expression.

validateRegExpLiteral(source, options?)

Validate a given regular expression literal.

This is equivalent to new RegExpValidator(options).validateLiteral(source).

visitRegExpAST(ast, handlers)

Visit each node of a given AST.

This is equivalent to new RegExpVisitor(handlers).visit(ast).

RegExpParser

new RegExpParser(options?)

parser.parseLiteral(source, start?, end?)

Parse a regular expression literal.

  • Parameters:
    • source (string) The source code to parse. E.g. "/abc/g".
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.
  • Return:
    • The AST of the regular expression.

parser.parsePattern(source, start?, end?, flags?)

Parse a regular expression pattern.

  • Parameters:
    • source (string) The source code to parse. E.g. "abc".
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.
    • flags? ({ unicode?: boolean, unicodeSets?: boolean }) The flags to enable Unicode mode, and Unicode Set mode.
  • Return:
    • The AST of the regular expression pattern.

parser.parseFlags(source, start?, end?)

Parse a regular expression flags.

  • Parameters:
    • source (string) The source code to parse. E.g. "gim".
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.
  • Return:
    • The AST of the regular expression flags.

RegExpValidator

new RegExpValidator(options)

validator.validateLiteral(source, start, end)

Validate a regular expression literal.

  • Parameters:
    • source (string) The source code to validate.
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.

validator.validatePattern(source, start, end, flags)

Validate a regular expression pattern.

  • Parameters:
    • source (string) The source code to validate.
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.
    • flags? ({ unicode?: boolean, unicodeSets?: boolean }) The flags to enable Unicode mode, and Unicode Set mode.

validator.validateFlags(source, start, end)

Validate a regular expression flags.

  • Parameters:
    • source (string) The source code to validate.
    • start? (number) The start index in the source code. Default is 0.
    • end? (number) The end index in the source code. Default is source.length.

RegExpVisitor

new RegExpVisitor(handlers)

visitor.visit(ast)

Validate a regular expression literal.

  • Parameters:

📰 Changelog

🍻 Contributing

Welcome contributing!

Please use GitHub's Issues/PRs.

Development Tools

  • npm test runs tests and measures coverage.
  • npm run build compiles TypeScript source code to index.js, index.js.map, and index.d.ts.
  • npm run clean removes the temporary files which are created by npm test and npm run build.
  • npm run lint runs ESLint.
  • npm run update:test updates test fixtures.
  • npm run update:ids updates src/unicode/ids.ts.
  • npm run watch runs tests with --watch option.
hooksmomentArray.prototype.findLastmulti-packageESnextfscloudsearchdeterministicfpsTypeBoxproxyimportprototypeutilsajaxelectronvpcenumerablelastworkerfast-copymakechaiformBigUint64Arrayhardlinksstreamsgloballogenvironmentsreact animationinferencerestsuperagentwebgraphqlfeedpropfullwidthspinnerses8point-freeloggingindeepcharacterdataViewtypedcollection.es6StreamsJSON-Schemauninstallstylingobjescapequerystringqscodesdirimportexporttouch@@toStringTagcryptoArray.prototype.includessharedarraybufferbrowserlistsymbolsinputregular expressionsECMAScript 6diffWeakSetspawnzodeslint-plugineventslrujsxformat0file systemuser-streamsObject.getPrototypeOfbinarysessettingsWebSocketArrayBuffer#slicenodejsestreetypedarrayscolumnvaluedataviewObject.isgesturesquotemkdircjkflatxmlgetsearchdropminimalconsumeES2023mruparsesafechineseflagstc39fastifyes2017Observablesswfhas-ownboundInt32Arrayperformancechildpostcss-pluginchromerangeerrortoolkitglobalThisdatazxTypeScriptnegative zerowindowsimpledbcomputed-typesbyteOffsetpyyamlreusetrimsetobject.gitignorelengthvalidationESsource mapebscall-bindomitcurlsameValueZerotrimRightlintcloneiterateserializebinariesapphttpsObject.keysponyfillregular-expressiontrimLeftapollojson-schema-validationnegativeglobalsrecursivecollectiontoArrayoptionphoneObject.valuespackageses6String.prototype.trimloggerStyleSheetloadbalancingformattingslot6to5ES2020loadingECMAScriptpnpm9Function.prototype.namedeletebeanstalklinkstyleguideeveryPromisefunctionexecuterdssetImmediatecoverageArray.prototype.findLastIndexttypicomatchmonoreporestfulReactiveXcontainssuperstructcallwidthmochatoStringTaggroupByqueryvaluesArray.prototype.filtereslintpluginmovepositivetestdescriptiondragcensorassertion.envsortbindrmdirreact posebundlerunicodeajvlocalexpress3dstoragegatewaycacheUint8ArrayRegExp.prototype.flagsutilitiesdependenciesprivateownlocationspringkeysextramatchAll
2.4.65

2 years ago

2.4.64

2 years ago

2.4.61

2 years ago

2.4.63

2 years ago

2.4.62

2 years ago

2.4.58

2 years ago

2.4.59

2 years ago

2.4.60

2 years ago

2.4.57

2 years ago

2.4.56

2 years ago

2.4.55

2 years ago

2.4.54

2 years ago

2.4.53

2 years ago

2.4.52

2 years ago

2.4.51

2 years ago

2.2.17

2 years ago

2.4.39

2 years ago

2.2.18

2 years ago

2.2.15

2 years ago

2.2.16

2 years ago

2.4.36

2 years ago

2.2.14

2 years ago

2.4.38

2 years ago

2.4.37

2 years ago

2.2.19

2 years ago

2.2.28

2 years ago

2.2.29

2 years ago

2.2.26

2 years ago

2.2.27

2 years ago

2.4.47

2 years ago

2.3.35

2 years ago

2.2.24

2 years ago

2.4.46

2 years ago

2.3.34

2 years ago

2.2.25

2 years ago

2.4.49

2 years ago

2.2.22

2 years ago

2.4.48

2 years ago

2.3.36

2 years ago

2.2.23

2 years ago

2.4.43

2 years ago

2.2.20

2 years ago

2.4.42

2 years ago

2.2.21

2 years ago

2.4.45

2 years ago

2.4.44

2 years ago

2.4.41

2 years ago

2.4.40

2 years ago

2.2.33

2 years ago

2.2.34

2 years ago

2.2.31

2 years ago

2.2.32

2 years ago

2.2.30

2 years ago

2.4.50

2 years ago

2.2.13

2 years ago

2.2.11

2 years ago

2.1.10

2 years ago

2.2.12

2 years ago

2.2.10

2 years ago

1.1.9

2 years ago

1.1.8

2 years ago

1.1.10

2 years ago

1.1.7

2 years ago

1.1.6

2 years ago

1.1.5

2 years ago

1.1.4

2 years ago

1.0.4

2 years ago

1.0.3

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago