Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
QuentinI committed Nov 5, 2024
1 parent ce8947c commit 9705123
Show file tree
Hide file tree
Showing 28 changed files with 1,473 additions and 2,564 deletions.
4 changes: 2 additions & 2 deletions .clippy.toml
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
disallowed-names = [ "TYPES" ]
doc-valid-idents = [ "HotShot", ".." ]
disallowed-names = ["TYPES"]
doc-valid-idents = ["HotShot", ".."]
1 change: 1 addition & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ jobs:
runs-on: ubuntu-latest
env:
RUSTFLAGS: '--cfg async_executor_impl="async-std" --cfg async_channel_impl="async-std"'
RUSTDOCFLAGS: '--cfg async_executor_impl="async-std" --cfg async_channel_impl="async-std"'
RUST_LOG: info
steps:
- uses: actions/checkout@v4
Expand Down
51 changes: 49 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 3 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@ bincode = "1.3"
clap = "4.5"
chrono = { version = "0.4", features = ["serde"] }
committable = "0.2"
derivative = "2.2"
concurrent-map = "5.0"
derive_more = "1.0"
either = "1.13"
futures = "0.3"
hex = "0.4.3"
Expand All @@ -40,6 +41,7 @@ tide-disco = "0.9"
tokio = "1"
toml = "0.8"
tracing = "0.1"
typenum = "1.17"
url = "2.3"
vbs = "0.1"
vec1 = "1.12"
Expand Down
1 change: 0 additions & 1 deletion crates/legacy/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ async-trait = { workspace = true }
bincode = { workspace = true }
clap = { workspace = true, features = ["derive", "env"] }
committable = { workspace = true }
derivative = { workspace = true }
futures = { workspace = true }
hex = { workspace = true }
hotshot = { workspace = true }
Expand Down
42 changes: 17 additions & 25 deletions crates/legacy/src/builder_state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,14 +10,13 @@ use hotshot_types::{
utils::BuilderCommitment,
vid::{VidCommitment, VidPrecomputeData},
};
use marketplace_builder_shared::block::{BlockId, BuilderStateId, ParentBlockReferences};
use marketplace_builder_shared::block::{
BlockId, BuilderStateId, ParentBlockReferences, ReceivedTransaction,
};

use committable::Commitment;

use crate::{
service::{GlobalState, ReceivedTransaction},
LegacyCommit,
};
use crate::{service::GlobalState, LegacyCommit};
use async_broadcast::broadcast;
use async_broadcast::Receiver as BroadcastReceiver;
use async_broadcast::Sender as BroadcastSender;
Expand All @@ -42,13 +41,6 @@ use std::{collections::hash_map::Entry, time::Duration};

pub type TxTimeStamp = u128;

/// Enum to hold the different sources of the transaction
#[derive(Clone, Debug, PartialEq)]
pub enum TransactionSource {
External, // txn from the external source i.e private mempool
HotShot, // txn from the HotShot network i.e public mempool
}

/// Decide Message to be put on the decide channel
#[derive(Clone, Debug)]
pub struct DecideMessage<Types: NodeType> {
Expand Down Expand Up @@ -669,13 +661,13 @@ impl<Types: NodeType> BuilderState<Types> {
<Types::BlockPayload as BlockPayload<Types>>::from_bytes(encoded_txns, metadata);
let txn_commitments = block_payload.transaction_commitments(metadata);

for tx in txn_commitments.iter() {
self.txns_in_queue.remove(tx);
for txn in txn_commitments.iter() {
self.txns_in_queue.remove(txn);
}

self.included_txns.extend(txn_commitments.iter());
self.tx_queue
.retain(|tx| self.txns_in_queue.contains(&tx.commit));
.retain(|txn| self.txns_in_queue.contains(&txn.commit));

if !txn_commitments.is_empty() {
self.allow_empty_block_until = Some(Types::View::new(
Expand Down Expand Up @@ -739,15 +731,15 @@ impl<Types: NodeType> BuilderState<Types> {
.max_block_size;
let transactions_to_include = self.tx_queue.iter().scan(0, |total_size, tx| {
let prev_size = *total_size;
*total_size += tx.len;
*total_size += tx.min_block_size;
// We will include one transaction over our target block length
// if it's the first transaction in queue, otherwise we'd have a possible failure
// state where a single transaction larger than target block state is stuck in
// queue and we just build empty blocks forever
if *total_size >= max_block_size && prev_size != 0 {
None
} else {
Some(tx.tx.clone())
Some(tx.transaction.clone())
}
});

Expand Down Expand Up @@ -1042,7 +1034,7 @@ impl<Types: NodeType> BuilderState<Types> {
txn_garbage_collect_duration: Duration,
validated_state: Arc<Types::ValidatedState>,
) -> Self {
let txns_in_queue: HashSet<_> = tx_queue.iter().map(|tx| tx.commit).collect();
let txns_in_queue: HashSet<_> = tx_queue.iter().map(|txn| txn.commit).collect();
BuilderState {
included_txns: HashSet::new(),
included_txns_old: HashSet::new(),
Expand Down Expand Up @@ -1123,16 +1115,16 @@ impl<Types: NodeType> BuilderState<Types> {
async fn collect_txns(&mut self, timeout_after: Instant) {
while Instant::now() <= timeout_after {
match self.tx_receiver.try_recv() {
Ok(tx) => {
if self.included_txns.contains(&tx.commit)
|| self.included_txns_old.contains(&tx.commit)
|| self.included_txns_expiring.contains(&tx.commit)
|| self.txns_in_queue.contains(&tx.commit)
Ok(txn) => {
if self.included_txns.contains(&txn.commit)
|| self.included_txns_old.contains(&txn.commit)
|| self.included_txns_expiring.contains(&txn.commit)
|| self.txns_in_queue.contains(&txn.commit)
{
continue;
}
self.txns_in_queue.insert(tx.commit);
self.tx_queue.push_back(tx);
self.txns_in_queue.insert(txn.commit);
self.tx_queue.push_back(txn);
}
Err(async_broadcast::TryRecvError::Empty)
| Err(async_broadcast::TryRecvError::Closed) => {
Expand Down
Loading

0 comments on commit 9705123

Please sign in to comment.