mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-08 20:09:44 +00:00
331d4d3e7f
* rename `database` -> `old_database` Keeping it around for reference until new implementation is complete. * create new `database/` skeleton * add `DATABASE.md` design doc skeleton * move design doc to `database/README.md` * add rough code * `lib.rs` -> `gist.rs` * database: use workspace deps * workspace: include `database/` as member CI will now include this crate. * cargo fmt * database: `AGPL` -> `MIT` * readme: add `TODO`s * add base files * cargo.toml: add `heed` feature * fix clippy * lib.rs: add extremely pedantic lints * readme: add `# Backends` * cargo.toml: add `cfg-if` * add `backend/` structure * base `database.rs` * cargo.toml: add `borsh` * backend: add `DATABASE_BACKEND` * base `error.rs` * base `database.rs` * base `transaction.rs` * base `table.rs` * lib.rs: add imports * add `pod.rs` * pod: use `Read/Write`, add tests for all primitive numbers * pod: impl Pod for `Vec<u8>`, `[u8; N]` * pod: add docs, add `private::Sealed` * pod: `to_writer`, `from_reader` The new `as_bytes` + `from_bytes` now allows (de)serializing from bytes directly instead of going through Read/Write. Different array return sizes are abstracted away with `-> impl AsRef<[u8]>` * pod: impl Pod for `Box<[u8]>` * pod: return `Err` on incorrect length in `from_bytes()` * pod: docs * pod: impl Pod for `Arc<[u8]>` * readme: docs * database: add `create_table()`, `get_table()` * table: `Pod` bound * backend: move into directories * pod: add `into_bytes()` * heed: impl `BytesEncode`, `BytesDecode` * add `actor`, `service` features The thread/actor system used will be gated behind `actor`, and the `tower/tokio` integration will be gated behind `service`. * add `lib.rs` docs * service: add `service.rs` * service: add `reader.rs` * service: add `writer.rs` * service: add `request.rs` & `response.rs` * cargo.toml: add `crossbeam` * service: add/use `enum Request`, `enum Response` * service: basic signatures for thread-pools, `Writer` -> `Writers` * service: split `tower::Service<ReadRequest/WriteRequest>` * service: impl `tower::Service` for `Database(Reader|Writer)` * service: add `init()`, impl basic `Reader/Writer` pools * service: add example `Request`'s * service: add example `ReadRequest` handling * temporarily allow clippy lints * readme: update file structure * transaction: add `RoTx::get_range()` * service: module docs * cargo.toml: add `cuprate-helper` * service: scale readers/writers based on thread count * database: change lifetimes * heed: impl Database for `heed` * heed: add `ConcreteRoTx`, `ConcreteRwTx`, impl Tx traits * docs * service: `read.rs` docs * service: `write.rs` docs * service: request/response docs * service: use `OnceLock` in `init()`, add `db_read()`, `db_write()` * service: leak database into `&'static` * database: add `#[inline]`, `#[cold]` * service: `free.rs` docs, more `#[inline]` + `#[cold]` * service: add `shutdown()` * service: add `Request::Shutdown` * service: `shutdown()` docs * heed: hide concrete tx types * lib.rs: add terms * split `Env` <-> `Database` * cargo.toml: add `paste` * database: add `tables/` * impl `serde/borsh` where possible * tables: add `Tables`, add test docs * make db backend mutually exclusive to fix `--all-features` * tables: use `$()*` in `tables!()` * cargo.toml: add `sanakirja 1.4.0` * sanakirja: impl `Env` * sanakirja: impl `Database` * sanakirja: impl `Transaction` * table: temporarily fix `sanakirja` K/V bounds * table: fix `#[cfg]` * cargo.toml: fix deps * lib.rs: docs * service: docs * readme: add files, update `# Documentation`, add `# Layers` * readme: `src/` file purpose * readme: `src/service/` file purpose * readme: `src/backend/` file purpose * fix `Cargo.lock` merge conflict * database: remove `gist.rs` * add to `constants.rs` * add top `//! comments` for files/modules * constants: add sanity-check test * service: add `only_one_database` test in `free.rs` * service: add `tests.rs` * remove unneeded markers + imports * backend: fix `get_range()`'s trait `impl` return * env: add `create_tables_if_needed()`, don't return `Option<Db>` * sort imports by `CONTRIBUTING.md` rules oops sorry boog * add `monero.rs` * monero: docs * database: add missing `RoTx/RwTx` inputs * backend: add missing `RoTx/RwTx` inputs * `monero.rs` trait -> free functions in `ops/` * pod: make methods infallible * ci: add `rustup update` step * service: use `Arc` instead of leaking, remove `db_read/db_write` * service: use `InfallibleOneshotReceiver` for readers * service: shutdown on error, add todos * service: remove `Request` * service: combine `ReadResponse` and `WriteResponse` * service: use `InfallibleOneshotReceiver` for writer * service: only spawn 1 writer, don't allow cloning writer handle * table: add associated `const CONSTANT_SIZE` * add `key.rs` + `trait Key`, add bound to `Table` * fix typos
92 lines
4.7 KiB
TOML
92 lines
4.7 KiB
TOML
[workspace]
|
|
resolver = "2"
|
|
|
|
members = [
|
|
"consensus",
|
|
"consensus/rules",
|
|
"cryptonight",
|
|
"database",
|
|
"helper",
|
|
"net/epee-encoding",
|
|
"net/fixed-bytes",
|
|
"net/levin",
|
|
"net/monero-wire",
|
|
"p2p/monero-p2p",
|
|
"p2p/address-book",
|
|
"pruning",
|
|
"test-utils",
|
|
]
|
|
|
|
[profile.release]
|
|
lto = true # Build with LTO
|
|
strip = "none" # Keep panic stack traces
|
|
codegen-units = 1 # Optimize for binary speed over compile times
|
|
opt-level = 3
|
|
|
|
[profile.dev]
|
|
lto = false
|
|
strip = "none"
|
|
# Not much slower compile times than opt-level 0, but much faster code.
|
|
opt-level = 1
|
|
|
|
[profile.dev.package."*"]
|
|
# Compile dependencies with max optimization.
|
|
# This is obviously slower on a cold build,
|
|
# but you only build these once.
|
|
opt-level = 3
|
|
|
|
[workspace.dependencies]
|
|
async-trait = { version = "0.1.74", default-features = false }
|
|
borsh = { version = "1.2.1", default-features = false }
|
|
bytes = { version = "1.5.0", default-features = false }
|
|
cfg-if = { version = "1.0.0", default-features = false }
|
|
clap = { version = "4.4.7", default-features = false }
|
|
chrono = { version = "0.4.31", default-features = false }
|
|
crypto-bigint = { version = "0.5.5", default-features = false }
|
|
crossbeam = { version = "0.8.4", default-features = false }
|
|
curve25519-dalek = { version = "4.1.1", default-features = false }
|
|
dalek-ff-group = { git = "https://github.com/Cuprate/serai.git", rev = "347d4cf", default-features = false }
|
|
dirs = { version = "5.0.1", default-features = false }
|
|
futures = { version = "0.3.29", default-features = false }
|
|
hex = { version = "0.4.3", default-features = false }
|
|
hex-literal = { version = "0.4", default-features = false }
|
|
monero-serai = { git = "https://github.com/Cuprate/serai.git", rev = "347d4cf", default-features = false }
|
|
multiexp = { git = "https://github.com/Cuprate/serai.git", rev = "347d4cf", default-features = false }
|
|
paste = { version = "1.0.14", default-features = false }
|
|
pin-project = { version = "1.1.3", default-features = false }
|
|
randomx-rs = { git = "https://github.com/Cuprate/randomx-rs.git", rev = "0028464", default-features = false }
|
|
rand = { version = "0.8.5", default-features = false }
|
|
rayon = { version = "1.8.0", default-features = false }
|
|
serde_bytes = { version = "0.11.12", default-features = false }
|
|
serde_json = { version = "1.0.108", default-features = false }
|
|
serde = { version = "1.0.190", default-features = false }
|
|
thiserror = { version = "1.0.50", default-features = false }
|
|
thread_local = { version = "1.1.7", default-features = false }
|
|
tokio-util = { version = "0.7.10", default-features = false }
|
|
tokio-stream = { version = "0.1.14", default-features = false }
|
|
tokio = { version = "1.33.0", default-features = false }
|
|
tower = { version = "0.4.13", default-features = false }
|
|
tracing-subscriber = { version = "0.3.17", default-features = false }
|
|
tracing = { version = "0.1.40", default-features = false }
|
|
|
|
## workspace.dev-dependencies
|
|
reqwest = { version = "0.11.24" }
|
|
proptest = { version = "1" }
|
|
proptest-derive = { version = "0.4.0" }
|
|
|
|
|
|
## TODO:
|
|
## Potential dependencies.
|
|
# arc-swap = { version = "1.6.0" } # Atomically swappable Arc<T> | https://github.com/vorner/arc-swap
|
|
# itoa = { version = "1.0.9" } # Fast integer to string formatting | https://github.com/dtolnay/itoa
|
|
# notify = { version = "6.1.1" } # Filesystem watching | https://github.com/notify-rs/notify
|
|
# once_cell = { version = "1.18.0" } # Lazy/one-time initialization | https://github.com/matklad/once_cell
|
|
# open = { version = "5.0.0" } # Open PATH/URL, probably for binaries | https://github.com/byron/open-rs
|
|
# regex = { version = "1.10.2" } # Regular expressions | https://github.com/rust-lang/regex
|
|
# ryu = { version = "1.0.15" } # Fast float to string formatting | https://github.com/dtolnay/ryu
|
|
# strum = { version = "0.25.0" } # Enum macros/traits | https://github.com/Peternator7/strum
|
|
|
|
# Maybe one day.
|
|
# disk = { version = "*" } # (De)serialization to/from disk with various file formats | https://github.com/hinto-janai/disk
|
|
# readable = { version = "*" } # Stack-based string formatting utilities | https://github.com/hinto-janai/readable
|
|
# json-rpc = { git = "https://github.com/hinto-janai/json-rpc" } # JSON-RPC 2.0 types
|