0.4.4 • Published 3 years ago

reco.io v0.4.4

Weekly downloads
60
License
MIT
Repository
github
Last release
3 years ago

RECO

Regular Expression COmpiler - Compile a regex ahead of time to code

Try

If you have node.js installed, you can immediatly try out reco:

# This will generate a file called regex.js that contains the code to match the regex
npx reco.io -o regex.js '/[a-z]+/i'

You can import it and use it in your js code:

import { generatedRegexMatcher } from './regex.js';
const result = generatedRegexMatcher(str);
console.log(result);

/*
Outputs:
{
  index: 0, // position in the string that matched
  matches: [ 'foo', 'bar'] // groups that matched
}
or null in case there is no match
*/

Idea

The idea is to generate code that matches a given regex at compile time. The goal is that this code can run faster or at least equaly fast as the built in native regex engine of V8. Small scale experimentation has shown that this is should be possible. But currently the generated code is 2-3x slower than the original engine. But I hope to be able to beat V8's engine with some help of the community, or maybe via Rust and WASM. As the last step of the of compilation is a simple code templating step, it should be possible to compile a regex to different target languages (Rust, Go, Java, Python). As a side effect you can now also get the same regex to work across different browsers and programming languages.

Current status

Reco has an extensive test suite and is able to compile complicated JS regex with all the fancy features JS regex has. If you find a unsupported feature or a wrong matching behauvior compared to V8's regex engine, please file an isssue with an example.

Roadmap

Two main goals

  • Port to other languages, first Rust to be able to compile to WASM
  • Improve performance of matching

Contributing

I'm open for PRs :)

If this project creates interest by the community, I'll put effort into creating a nice documentation on the internal workings of this project.

Built on these awesome projects

0.4.4

3 years ago

0.4.3

3 years ago

0.4.2

3 years ago

0.4.1

3 years ago

0.4.0

3 years ago

0.3.3

3 years ago

0.3.2

3 years ago

0.3.1

3 years ago

0.3.0

3 years ago

0.2.3

3 years ago

0.2.2

3 years ago

0.2.4

3 years ago

0.2.1

3 years ago

0.2.0

3 years ago

0.1.5

3 years ago

0.1.4

3 years ago

0.1.3

3 years ago

0.1.2

3 years ago

0.1.1

3 years ago

0.1.0

3 years ago