Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bakkdoor/rogato
A functional, declarative query-oriented programming language with an integrated graph database.
https://github.com/bakkdoor/rogato
databases functional-language functional-programming graph graph-database graph-processing rust-lang rust-language rustlang
Last synced: 3 months ago
JSON representation
A functional, declarative query-oriented programming language with an integrated graph database.
- Host: GitHub
- URL: https://github.com/bakkdoor/rogato
- Owner: bakkdoor
- License: bsd-3-clause
- Created: 2022-06-25T03:21:19.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-12T08:50:29.000Z (10 months ago)
- Last Synced: 2024-09-29T22:41:43.721Z (3 months ago)
- Topics: databases, functional-language, functional-programming, graph, graph-database, graph-processing, rust-lang, rust-language, rustlang
- Language: Rust
- Homepage:
- Size: 1.52 MB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# rogātō ⌘ 🏷
## A functional, declarative query-oriented programming language with an integrated graph database.
🛠 (Still WIP) 🛠
[![CI](https://github.com/bakkdoor/rogato/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/bakkdoor/rogato/actions/workflows/ci.yml)
## [![rogātō REPL code example](https://img.youtube.com/vi/ddv5kuEufZc/0.jpg)](https://www.youtube.com/watch?v=ddv5kuEufZc)
**rogātō** aims to provide a simple yet powerful functional programming interface to a built-in graph database, powered by [indradb](https://github.com/indradb/indradb).
The syntax is inspired mostly by languages like Elm, F#, Haskell and Elixir. The goal is to provide a basic standard library for common tasks. The language is still at a very early stage, so a lot is still missing.
More information will follow here as the language matures.
For some example source code and syntax ideas (still WIP), check out the code examples under [examples/](examples/) or the standard library under [lib/](lib/).### Language design goals
* Simple, typed, memory-safe functional core language for data processing
* Direct native access to built-in graph database
* First-class query manipulation support against graph db
* Symbolic language capabilities for easy knowledge graph construction and querying
* Easy importing of data from various data formats, ideally provided by std lib### Build instructions
#### LLVM v14 Dependency
*rogātō* depends on LLVM version 14 to build. LLVM is used by the [`compiler`](compiler/) crate to generate optimized native machine code.
LLVM website with documentation and installation instructions:
- https://llvm.orgLatest compatible LLVM release:
- https://github.com/llvm/llvm-project/releases/tag/llvmorg-14.0.6#### Build without optimizations (debug mode)
Build with cargo, Rust's package and build manager:
cargo b
#### Build with optimizations (release mode)
cargo b -r
#### Build and run tests (debug/test mode)
cargo t
#### Build and run clippy linter
cargo clippy
#### Build with parser tracing enabled
cargo b --features trace
This works also for release builds:
cargo b -r --features trace
To get parser tracing viz via pegviz, run:
./target/release/rogato examples/query.roga | pegviz --output pegviz.html
Then open pegviz.html to view parser tracing visualization.
### Q&A
#### Why?
I needed a project to learn Rust with. I always have been interested in graph databases and their applications to data problems and have been fascinated by what declarative programming can do for simplicity in querying large data sets.
**rogātō** aims to unify some ideas and properties from functional and logic programming as well as graph databases into something new and cohesive that is fun and productive to use and can aid in discovering interesting facts about large data sets.#### What does the name mean?
**rogātō** is the ablative case of the Latin perfect passive participle of [***rogātus***](https://en.wiktionary.org/wiki/rogatus#Etymology_2) (having been enquired / asked / requested / invited).
###### How is it pronounced?
###### The a and final o (marked with macrons) are pronounced twice as long as the first o.