3.2.0 • Published 3 years ago

regexpp v3.2.0

Weekly downloads
17,069,804
License
MIT
Repository
github
Last release
3 years ago

regexpp

npm version Downloads/month Build Status codecov Dependency Status

A regular expression parser for ECMAScript.

💿 Installation

$ npm install regexpp
  • require Node.js 8 or newer.

📖 Usage

import {
    AST,
    RegExpParser,
    RegExpValidator,
    RegExpVisitor,
    parseRegExpLiteral,
    validateRegExpLiteral,
    visitRegExpAST
} from "regexpp"

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?, uFlag?)

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.
    • uFlag? (boolean) The flag to enable Unicode 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, uFlag)

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.
    • uFlag? (boolean) The flag to enable Unicode 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.
eslint-plugin-es@huyhpham/rn-linereact-native-bluetooth2killi8n-react-native-fast-imagepipihome@icanpm/api-mastereslint-4-fix@oneplanetcrowd/developers@almeidaa/msreact-native-template-rfbaseairscanairscan-examplebb-chatreact-native-esc-pos-sahaab@borisovart/atol-kkt-moduledeneme323112@ntt_app/react-native-custom-notificationagreestudioeslintreact-native-covid-sdkgql_din_modmutasi-bca@jttechnic/interpreter@saeon/quick-formcthpb-plugin-social@iobroker-community-adapters/iobroker.device-watchermysql-formatreact-native-printer-brothers@belko.tech/belko-multi-wallet-sdk@newhorizon-tech/dd-npm-package-templatereact-native-shekhar-bridge-testcogoportutilsukor-remasteruncoded-connect@reversodev/oceanic-fleetwilscanner@khalitovadel/abstract-repository@oiti/documentoscopy-react-native@respondea/cordova-plugin-v-inappbrowserquoc-testreact-native-slider-kf@infinitebrahmanuniverse/nolb-regeplginexpand-react-bridge@everything-registry/sub-chunk-2643p149-tableec0lint-style-config-postcssec0lintdynamics-contracts-xeditorjs_forkededitor.js-custom-multiple-selectedelvydskcoreneweslint-plugin-prototypeeslint-config-k3cman-angulardualite-application-formeslint-config-lucas-silbernageleslint4beslint-plugin-templewallet-testeslint-pceslint-nullish-coalescingoracle-zkappowt-client-javascriptp147-tablep148-tablenka-gantt-task-reactnpm_qwertynpm_one_12_34_1_npm_one_1_2_3npm_one_2_2numhandlermmir-plugin-exportsmicroend-componentpayutestingplugn-devicepensions_jordimrnuxtjs-argonprasadacmmoonwalkerswap-default-token-listsmpesa-cookiempesa-cookie-jarnative-google-loginnative-kakao-logingitbook-plugin-toc-xiayureact-native-create-video-thumbnailhcm-jsgrids-over-polygongoogle-remakeemr-tabulator-tableseslint-plugin-es-roikoreneslint-plugin-esxxeslint-plugin-eslint-badineslint-plugin-clean-regexeslint-plugin-dd-eslint-ruleses-react-bridgeeslint-badinesgrindex-ikon-components-libraryenefti-galeriepm-npm-tscevanutils
3.2.0

3 years ago

3.1.0

4 years ago

3.0.0

5 years ago

2.0.1

6 years ago

2.0.0

6 years ago

2.0.0-beta.0

6 years ago

1.1.0

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago

0.0.0

6 years ago