Fork of https://github.com/oxigraph/oxigraph.git for the purpose of NextGraph project
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Yuri Astrakhan d4bfcd3b24 Add debug print to test_debian_compatibility 2 years ago
.clusterfuzzlite Migrates RDF/XML parser from Rio 2 years ago
.github oxttl: Exposes the base IRI 2 years ago
bench Renames oxigraph-server to oxigraph(-cli) 2 years ago
cli Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
docs Architecture diagram 2 years ago
fuzz Parsers: adds "unchecked" option for faster parsing 2 years ago
js Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
lib Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
lints Add debug print to test_debian_compatibility 2 years ago
oxrocksdb-sys Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
python Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
testsuite Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
.dockerignore Fixes a style problem in pyoxigraph Cargo.toml 5 years ago
.gitignore Auto generates pyoxigraph type stubs 3 years ago
.gitmodules Run RDF canon tests to check isomorphism 2 years ago
.mailmap Make all Thomases into one 3 years ago
.readthedocs.yaml ReadTheDocs: updates Rust version 2 years ago
CHANGELOG.md Releases v0.4.0-alpha.2 2 years ago
CITATION.cff Adds DOI to CITATION.cff 3 years ago
Cargo.lock Turtle: fixes parsing bug with escaped dot at the end of a local name 2 years ago
Cargo.toml Enables cargo semver-checks again 2 years ago
LICENSE-APACHE Initial commit 8 years ago
LICENSE-MIT Update LICENSE-MIT 6 years ago
README.md Architecture diagram 2 years ago
clippy.toml XSD type structs: use by-value instead of by-ref in methods 2 years ago
deny.toml Upgrades RocksDB to 7.0 4 years ago
logo.svg Adds Oxigraph logo 5 years ago
rustfmt.toml Improves Rustfmt and Clippy configuration 3 years ago
server Renames oxigraph-server to oxigraph(-cli) 2 years ago
typos.toml Adds a typo linter as part of the CI 3 years ago

README.md

Oxigraph

Latest Version Released API docs PyPI npm actions status dependency status Gitter Twitter URL

Oxigraph is a graph database implementing the SPARQL standard.

Its goal is to provide a compliant, safe, and fast graph database based on the RocksDB key-value store. It is written in Rust. It also provides a set of utility functions for reading, writing, and processing RDF files.

Oxigraph is in heavy development and SPARQL query evaluation has not been optimized yet. The development roadmap is using GitHub milestones. Oxigraph internal design is described on the wiki.

Oxigraph implements the following specifications:

It is split into multiple parts:

Also, some parts of Oxigraph are available as standalone Rust crates:

  • oxrdf, datastructures encoding RDF basic concepts (the oxigraph::model module).
  • oxrdfio, a unified parser and serializer API for RDF formats (the oxigraph::io module). It itself relies on:
    • oxttl, N-Triple, N-Quad, Turtle, TriG and N3 parsing and serialization.
    • oxrdfxml, RDF/XML parsing and serialization.
  • spargebra, a SPARQL parser.
  • sparesults, parsers and serializers for SPARQL result formats.
  • sparopt, a SPARQL optimizer.
  • oxsdatatypes, an implementation of some XML Schema datatypes.

The library layers in Oxigraph. The elements above depend on the elements below: Oxigraph libraries architecture diagram

A preliminary benchmark is provided. There is also a document describing Oxigraph technical architecture.

When cloning this codebase, don't forget to clone the submodules using git clone --recursive https://github.com/oxigraph/oxigraph.git to clone the repository including submodules or git submodule update --init to add the submodules to the already cloned repository.

Help

Feel free to use GitHub discussions or the Gitter chat to ask questions or talk about Oxigraph. Bug reports are also very welcome.

If you need advanced support or are willing to pay to get some extra features, feel free to reach out to Tpt.

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Oxigraph by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Sponsors

And others. Many thanks to them!