os2ds-rules
is the next-generation rules system for use in OS2datascanner
by Magenta ApS, which aimes to deliver high-performance
with regards to processing speed and detection accuracy.
The project consists of several components:
- A shared-library backend written in modern
C++20
. - A Python C/C++ extension that exposes functionality from the backend to
python
. - A
python
library that provides a safe, easy-to-use interface to the aforementioned extension.
WARNING: This is currently in a very early stage of development and frequently undergoes substantial changes, so it is not ready for prime time, yet.
You can install either or both of the C++
library or the python
extension.
For the C++
library you need a few different things:
- A compiler that supports
C++20
. We recommend using eitherg++
(GCC) orclang
(LLVM). cmake>=3.20
: Primary (meta) build system.ninja
: Cross-platform backend for cmake.gtest
(Google Test): For building and running the test suite.
For development, you additionally want:
cppcheck
orclang-analyzer
: For static code analysis.clang-format
: For formatting C++ code. We adhere to the LLVM style guide.clang-tidy
: For C++ code linting.gdb
orlldb
: A suitable debugger.
To make a debug build on linux
, run the following:
# Make a build directory
cmake . --preset linux-debug
cmake --build --preset linux-build-debug
This will build the shared library libos2dsrules.so
and the test suite testsuite
.
To install the library, run the following from the build directory:
sudo cmake --install build_cmake/debug
By default, this will install headers into /usr/include
and shared objects to
/usr/lib
.
To run the test suite:
ctest --preset linux-test-debug
Currently, this has only been tested on linux
.
It remains to be tested on windows
and macos
.
There are four preconfigured workflows that has been automated with cmake:
linux-debug-workflow
: Configures, Builds and Tests the debug version of the library forlinux
.linux-release-workflow
: Configures, Builds and Packages the release version of the library forlinux
.windows-debug-workflow
: Configures, Builds and Tests the debug version of the library forwindows
.windows-release-workflow
: Configures, Builds and Packages the release version of the library forwindows
.
For example, to run a debugging workflow on linux, use:
cmake --workflow --preset linux-debug-workflow
You need the following:
- A compiler that supports
C++20
. We recommend using eitherg++
(GCC) orclang
(LLVM). - The CPython development headers and libraries.
setuptools
: For building the extension.pytest
: For python tests.pytest-benchmark
: For python benchmarks.
NOTE: Depending on what OS you use and how CPython
was installed on your system,
the development headers and libraries may or may not be installed.
The development headers and libraries can be installed using a package manager on the following systems:
ubuntu
/debian
:sudo apt install python3-dev
fedora
:sudo dnf install python3-devel
To build the extension:
# From the project root.
python3 -m setup build
To install the extension locally:
# From the project root.
# You may want to use the `-e` option during development.
python3 -m pip install .
Uninstalling is as easy as running:
pip uninstall os2ds-rules
After having installed the extension as described above, run the benchmarks with:
python3 -m pytest --benchmark-only test/benchmarks/
Currently, you need to build and install the extension before running the benchmark until this gets fixed.
The Python3 extension uses the CPython
C-API, which is supported by
CPython
as standard.
We aim to support the PyPy
interpreter as well.
Let us scan a python str
for occurances for CPR-Numbers:
from os2ds_rules import CPRDetector
detector = CPRDetector()
matches = detector.find_matches('This is a fake, but valid CPR-Number: 1111111118')
for m in matches:
print(m)
Consider this simple file, test.cpp
:
#include <os2dsrules.hpp>
#include <name_rule.hpp>
#include <iostream>
#include <string>
using namespace OS2DSRules::NameRule;
int main(void) {
NameRule rule;
std::string s = "This is my friend, John.";
auto results = rule.find_matches(s);
std::cout << "Found matches: \n";
for (auto m : results) {
std::cout << m.match() << '\n';
}
return 0;
}
To compile, using clang
, simply run:
clang++ -los2dsrules -std=c++20 test.cpp -o test
This will produce an executable test
in the current working directory.
Running it:
$ ./test
Found matches:
John