This is an open source library and, standalone application that supports the searching of MTG cards and sets. It has a syntax that is similar to Scryfall but it can be embedded anywhere.
- cmake+
- openssl+
- cURL+
- jansson+
- c compiler (i.e: gcc, msvc, clang)
- c++ compiler (i.e: g++, msvc, clang)
- pthread (see win32 pthread)
- python3
pip install -r requirements.txt
- these can be included via submodules, see the SquireDesktop repo for an example
- astyle
- cmake-formatter
- ctest
- valgrind
- libmedtls (web-api)
This project is written in C and, targets all platforms. There is an optional frontend and web API for this project, these can simply not be built.
cd backend/
# You might want to use a Nix shell to install things for you
nix-shell shell.nix
# Or on mac
# nix-shell shell_mac.nix
# You should be in a python virtual environment
python -m venv .
# If you are on windows or use fish, you must change this line
source bin/activate
pip install -r requirements.txt
# .
mkdir -p build
cd build
# ./build/
# You can use -DMSE_DOXYGEN=ON to generate documentation
# You can use -DUSE_GCOV=OFF to disable gcov
cmake -DUSE_JEMALLOC=ON ..
cmake --build . -j
ctest -V -j # Runs all the tests
Local test flag for slow internet: MSE_TEST
, use this to make the program always read a cached copy of AllPrintings.json,
really useful when running on crap internet.
export MSE_TEST=true
./mtg-search-engine-tests
The frontend uses NextJS with the app dir.
cd frontend
npm i
npm build