|
# RREX
|
|
|
|
## Regular expression interpreter / validator
|
|
|
|
This regular expression validator is made with the target to be faster than the glibc regular expression validator and with success. In 23/25 tests it scores a better result than the original glibc validator. My bytecode compiler is way faster than the one provided by glibc and my executor often. For single validation, my validator is always a better choice.
|
|
|
|
## Benchmark and test
|
|
Benchmark vs. glibc regex. (Animated gif, takes some time to load)
|
|
|
|
![Gif of build process](build.gif)
|
|
|
|
## Todo / issues
|
|
- Segmenation fault fix is expr ends with \\d?
|
|
- rassert(!rrex("123", "[123]+b")); doesn't work
|
|
- abc with abc[gg]d matches valid. Shouldn't be so
|
|
|
|
## Make
|
|
|
|
### `all:`
|
|
Runs the following tasks sequentially:
|
|
- **`one-file:`** Merges, formats, and compiles a single C file.
|
|
- **`format_all:`** Formats all `.c` and `.h` files using `clang-format`.
|
|
- **`build:`** Compiles the main program (`rrex2.c`) with optimization and static linking.
|
|
- **`run:`** Executes the compiled program (`rrex2`).
|
|
|
|
### `format_all:`
|
|
Formats all `.c` and `.h` files in the directory using `clang-format`.
|
|
|
|
### `build:`
|
|
Compiles `rrex2.c` into an executable named `rrex2` with optimization (`-O2`), all warnings enabled (`-Wall`), and extra warnings enabled (`-Wextra`). The executable is statically linked.
|
|
|
|
### `run:`
|
|
Runs the compiled program (`rrex2`).
|
|
|
|
### `test:`
|
|
Rebuilds the project by running the `build` target and then runs the program with `test` as an argument.
|
|
|
|
### `cli:`
|
|
Runs the `build` target and then executes the program in CLI mode.
|
|
|
|
### `compiler:`
|
|
Compiles `compiler.c` into an optimized executable `compiler.o` and then runs it.
|
|
|
|
### `backup:`
|
|
Creates a compressed archive (`rrex.rzip`) of all `.c`, `.h`, Makefile, and markdown files in the directory.
|
|
|
|
### `coverage:`
|
|
Generates code coverage information:
|
|
- Removes existing coverage data files.
|
|
- Compiles `rrex2.c` with profiling and test coverage flags.
|
|
- Executes the compiled coverage binary with `test` as an argument.
|
|
- Captures coverage data with `lcov` and generates an HTML report using `genhtml`.
|
|
- Opens the coverage report in Google Chrome.
|
|
- Cleans up intermediate coverage files and the binary.
|