Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ts-regex-builder

Package Overview
Dependencies
Maintainers
0
Versions
23
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ts-regex-builder

Maintainable regular expressions for TypeScript and JavaScript.

  • 1.8.2
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
20K
increased by1.25%
Maintainers
0
Weekly downloads
 
Created
Source

npm version Build npm bundle size PRs Welcome Star on GitHub

TS Regex Builder

Build maintainable regular expressions for TypeScript and JavaScript.

API docs | Examples

Goal

Regular expressions are a powerful tool for matching text patterns, yet they are notorious for their hard-to-parse syntax, especially in the case of more complex patterns.

This library allows users to create regular expressions in a structured way, making them easy to write and review. It provides a domain-specific langauge for defining regular expressions, which are finally turned into JavaScript-native RegExp objects for fast execution.

// Regular JS RegExp
const hexColor = /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/;

// TS Regex Builder DSL
const hexDigit = /[a-fA-F0-9]/; // or: charClass(charRange('a', 'f'), charRange('A', 'F'), charRange('0', '9'));

const hexColor = buildRegExp([
  startOfString,
  optional('#'),
  capture(
    choiceOf(
      repeat(hexDigit, 6), // #rrggbb
      repeat(hexDigit, 3), // #rgb
    ),
  ),
  endOfString,
]);

Installation

npm install ts-regex-builder

or

yarn add ts-regex-builder

Basic usage

import { buildRegExp, capture, oneOrMore } from 'ts-regex-builder';

// /Hello (\w+)/
const regex = buildRegExp(['Hello ', capture(oneOrMore(word))]);

Regex domain-specific language

TS Regex Builder allows you to build complex regular expressions using domain-specific language.

Terminology:

  • regex construct (RegexConstruct) - common name for all regex constructs like character classes, quantifiers, and anchors.
  • regex element (RegexElement) - a fundamental building block of a regular expression, defined as either a regex construct, a string, or RegExp literal (/.../).
  • regex sequence (RegexSequence) - a sequence of regex elements forming a regular expression. For developer convenience, it also accepts a single element instead of an array.

Most of the regex constructs accept a regex sequence as their argument.

Examples of sequences:

  • single element (construct): capture('Hello')
  • single element (string): 'Hello'
  • single element (RegExp literal): /Hello/
  • array of elements: ['USD', oneOrMore(digit), /Hello/]

Regex constructs can be composed into a tree structure:

const currencyCode = repeat(charRange('A', 'Z'), 3);
const currencyAmount = buildRegExp([
  choiceOf('$', '€', currencyCode), // currency
  capture(
    oneOrMore(digit), // integer part
    optional(['.', repeat(digit, 2)]), // fractional part
  ),
]);

See Types API doc for more info.

Regex Builders

BuilderRegex SyntaxDescription
buildRegExp(...)/.../Create RegExp instance
buildRegExp(..., { ignoreCase: true })/.../iCreate RegExp instance with flags

See Builder API doc for more info.

Regex Constructs

ConstructRegex SyntaxNotes
choiceOf(x, y, z)x|y|zMatch one of provided sequences
capture(...)(...)Create a capture group

See Constructs API doc for more info.

[!NOTE] TS Regex Builder does not have a construct for non-capturing groups. Such groups are implicitly added when required.

Quantifiers

QuantifierRegex SyntaxDescription
zeroOrMore(x)x*Zero or more occurrence of a pattern
oneOrMore(x)x+One or more occurrence of a pattern
optional(x)x?Zero or one occurrence of a pattern
repeat(x, n)x{n}Pattern repeats exact number of times
repeat(x, { min: n, })x{n,}Pattern repeats at least given number of times
repeat(x, { min: n, max: n2 })x{n1,n2}Pattern repeats between n1 and n2 number of times

See Quantifiers API doc for more info.

Assertions

AssertionRegex SyntaxDescription
startOfString^Match the start of the string (or the start of a line in multiline mode)
endOfString$Match the end of the string (or the end of a line in multiline mode)
wordBoundary\bMatch the start or end of a word without consuming characters
lookahead(...)(?=...)Match subsequent text without consuming it
negativeLookahead(...)(?!...)Reject subsequent text without consuming it
lookbehind(...)(?<=...)Match preceding text without consuming it
negativeLookbehind(...)(?<!...)Reject preceding text without consuming it

See Assertions API doc for more info.

Character classes

[!TIP] You may also use inline regexes for specifying character classes, as they offer a concise yet readable syntax. For example, /[a-z0-9_]/.

Character classRegex SyntaxDescription
any.Any character
word\wWord character: letter, digit, underscore
digit\dDigit character: 0 to 9
whitespace\sWhitespace character: space, tab, line break, ...
anyOf('abc')[abc]Any of provided characters
charRange('a', 'z')[a-z]Character in a range
charClass(...)[...]Union of multiple character classes
negated(...)[^...]Negation of a given character class

See Character Classes API doc and Unicode API doc for more info.

Examples

See Examples.

Performance

Regular expressions created with this library are executed at runtime, so you should avoid creating them in a context where they would need to be executed multiple times, e.g., inside loops or functions. We recommend that you create a top-level object for each required regex.

Contributing

See the contributing guide to learn how to contribute to the repository and the development workflow. See the project guidelines to understand our core principles.

License

MIT

Inspiration

TS Regex Builder is inspired by Swift Regex Builder API.

Reference


Made with create-react-native-library

Keywords

FAQs

Package last updated on 09 Sep 2024

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc