|
4169c45c58
|
Blockchain: add alt-block handling (#260)
* add new tables & types
* add function to fully add an alt block
* resolve current todo!s
* add new requests
* WIP: starting re-orgs
* add last service request
* commit Cargo.lock
* add test
* more docs + cleanup + alt blocks request
* clippy + fmt
* document types
* move tx_fee to helper
* more doc updates
* fmt
* fix imports
* fix fee
* Apply suggestions from code review
Co-authored-by: hinto-janai <hinto.janai@protonmail.com>
* remove default features from `cuprate-helper`
* review fixes
* fix find_block
* add a test and fix some issues in chain history
* fix clippy
* fmt
* Apply suggestions from code review
Co-authored-by: hinto-janai <hinto.janai@protonmail.com>
* add dev dep
* cargo update
* move `flush_alt_blocks`
* review fixes
* more review fixes
* fix clippy
* remove INVARIANT comments
---------
Co-authored-by: hinto-janai <hinto.janai@protonmail.com>
|
2024-09-19 16:55:28 +01:00 |
|
hinto-janai
|
eead49beb0
|
lints: opt in manual lint crates (#263)
* cargo.toml: transfer existing lints
* rpc/interface: lints
* rpc/json-rpc: lints
* rpc/types: lints
* storage/blockchain: lints
* rpc/types: fix lints
* cargo.toml: fix lint group priority
* storage/blockchain: fix lints
* fix misc lints
* storage/database: fixes
* storage/txpool: opt in lints + fixes
* types: opt in + fixes
* helper: opt in + fixes
* types: remove borsh
* rpc/interface: fix test
* test fixes
* database: fix lints
* fix lint
* tabs -> spaces
* blockchain: `config/` -> `config.rs`
|
2024-09-02 18:12:54 +01:00 |
|
hinto-janai
|
bec8cc0aa4
|
helper: add and use cast module (#264)
* helper: add `cast` module
* fix crates
* spacing
|
2024-09-02 18:09:52 +01:00 |
|
hinto-janai
|
9c27ba5791
|
database: impl service fn bodies (#113)
* write: impl write_block()
* ops: add `get_block_info()`
* read: impl block fn's
* read: fix signatures
* service: wrap `ConcreteEnv` in `RwLock` and doc why
* heed: use `read-txn-no-tls` for `Send` read transactions
* service: remove RwLock, impl some read functions
* read: impl `outputs()`
* read: flatten indentation, add `thread_local()`
* read: impl `number_outputs_with_amount()`
* tests: add `AssertTableLen`
* ops: replace all table len asserts with `AssertTableLen`
* service: initial tests
* service: finish most tests
* service: fix bad block data in test
* tables: fix incorrect doc
* service: add `ReadRequest::Outputs` test
* read: use macros for set/getting `ThreadLocal`'s based on backend
* small fixes
* fix review
* small fixes
* read: fix ThreadLocal macros for `redb`
* read: move `Output` mapping to `crate::free`
it's needed in tests too
* service: check output value correctness in tests
* helper: add timelock <-> u64 mapping functions
* free: use `u64_to_timelock()`
* read: rct outputs
* read: fix variable name
* read: use ThreadLocal for both backends
* heed: use Mutex for `HeedTableRo`'s read tx
* block: add miner_tx
* heed: remove Table bound
oops
* Revert "heed: use Mutex for `HeedTableRo`'s read tx"
This reverts commit 7e8aae016c55802070ccf7d152aa8966984d7186.
* add `UnsafeSendable`
* read: use `UnsafeSendable` for `heed`, branch on backend
* read: safety docs
* cargo.toml: re-add `read-txn-no-tls` for heed
* ops: fix tests, remove miner_tx
* fix tx_idx calculation, account for RCT outputs in tests
* read: docs, fix `get_tables!()` for both backends
* fix clippy
* database: `unsafe trait DatabaseRo`
* tx: use correct tx_id
* free: remove miner_tx comment
* free: remove `amount` input for rct outputs
* ops: split `add_tx` inputs
* read: use `UnsafeSendable` for all backends
* heed: update safety comment
* move output functions `free` -> `ops`
* read: fix `chain_height()` handling
* remove serde on `UnsafeSendable`
* de-dup docs on `trait DatabaseRo`, `get_tables!()`
* Update database/src/unsafe_sendable.rs
Co-authored-by: Boog900 <boog900@tutanota.com>
---------
Co-authored-by: Boog900 <boog900@tutanota.com>
|
2024-05-01 18:52:20 +01:00 |
|
hinto-janai
|
bf6c21c71e
|
database: split cumulative_difficulty into low/high bits (#114)
* types: split `cumulative_difficulty` into low/high bits
* helper: add `map` module
* database: use `helper`'s cumulative_diff functions
* helper: rename functions
splitting bits isn't necessarily `cumulative_difficulty` specific
* database: fix tests
* helper: docs
* helper: test output is low-endian bits
* helper: docs
* Update helper/src/map.rs
Co-authored-by: Boog900 <boog900@tutanota.com>
* Update helper/src/map.rs
Co-authored-by: Boog900 <boog900@tutanota.com>
---------
Co-authored-by: Boog900 <boog900@tutanota.com>
|
2024-04-24 21:47:48 +01:00 |
|
hinto-janai
|
e287ea1d84
|
helper: add fs (#67)
* helper: add `fs`
* fs: docs
* remove `cuprate_create_dir_all()`
Calling each function is better.
* fs: comments
* helper: fix `asynch` tokio import for tests
* fs: add sanity tests
* fs: add `is_absolute()` to tests
* fs: assert path is absolute
* Update helper/src/fs.rs
Co-authored-by: Boog900 <boog900@tutanota.com>
* Update helper/src/fs.rs
Co-authored-by: Boog900 <boog900@tutanota.com>
---------
Co-authored-by: Boog900 <boog900@tutanota.com>
|
2024-02-21 17:54:46 +00:00 |
|
hinto-janai
|
a58d33b95e
|
helper: add constants & COMMIT (#64)
* helper: add `build.rs`
* helper: add `constants` feature
* helper: add `constants.rs`
* helper: use `.as_bytes()` for commit hash length check
* helper: `to_lowercase()` and `trim()` to `COMMIT`
|
2024-02-15 21:44:43 +00:00 |
|
hinto-janai
|
ba0f82c356
|
helper: use crossbeam::atomic::AtomicCell for atomic floats (#56)
* cargo.toml: add `crossbeam`
* helper: use `crossbeam::atomic::AtomicCell` for `AtomicF(32|64)`
* helper: atomic docs
|
2024-02-10 23:19:12 +00:00 |
|
Boog900
|
ed598e374e
|
remove empty cuprate bin and common
|
2024-01-22 01:56:34 +00:00 |
|
Boog900
|
b9334b6a90
|
clean up dependencies
|
2024-01-21 14:46:03 +00:00 |
|
hinto-janai
|
50894bef89
|
helper/ (#45)
* add `/helper/`
* add `num.rs`
* add `sys.rs`
* add `crypto.rs`
* add lints and mod to `lib.rs`
* `sys` -> `time`, add more free functions
straight from https://docs.rs/readable/latest/readable/time/index.html
* num: add `Number/Float` types, `cmp_float()`, `cmp_float_nan()`
* `common/src/tower_utils.rs` -> `helper/src/asynch.rs`
* gate modules with `#[cfg(feature = "...")]`
* add `thread.rs`
* cargo fmt
* thread: test out of 100
* add `atomic.rs`
* atomic: fix `fetch_update()`
* atomic: impl `fetch_*()` for atomic floats
* `#[no_std]` where possible
* asynch: remove `InstaFuture`
https://docs.rs/futures/latest/futures/future/fn.ready.html
* crypto: remove `check_point()`
* thread: return percent computation without static
* thread: add `low_priority_thread()`
https://docs.rs/lpt
* add rayon_spawn_async, remove crypto
* remove current_time_try
---------
Co-authored-by: Boog900 <54e72d8a-345f-4599-bd90-c6b9bc7d0ec5@aleeas.com>
|
2024-01-21 00:04:09 +00:00 |
|