Move peer state to a separate file
This commit is contained in:
parent
0d85eb9f2a
commit
1e478aabac
5 changed files with 33 additions and 23 deletions
|
|
@ -7,6 +7,7 @@ pub mod lengths;
|
|||
pub mod peer_binary_protocol;
|
||||
pub mod peer_connection;
|
||||
pub mod peer_id;
|
||||
pub mod peer_state;
|
||||
pub mod serde_bencode;
|
||||
pub mod spawn_utils;
|
||||
pub mod torrent_manager;
|
||||
|
|
|
|||
|
|
@ -17,7 +17,8 @@ use crate::{
|
|||
},
|
||||
peer_id::try_decode_peer_id,
|
||||
spawn_utils::{spawn, spawn_blocking},
|
||||
torrent_state::{InflightRequest, PeerHandle, TorrentState},
|
||||
torrent_state::{InflightRequest, TorrentState},
|
||||
type_aliases::PeerHandle,
|
||||
};
|
||||
|
||||
#[derive(Clone)]
|
||||
|
|
|
|||
24
crates/librqbit/src/peer_state.rs
Normal file
24
crates/librqbit/src/peer_state.rs
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
use std::{collections::HashSet, net::SocketAddr, sync::Arc};
|
||||
|
||||
use tokio::sync::{Notify, Semaphore};
|
||||
|
||||
use crate::{torrent_state::InflightRequest, type_aliases::BF};
|
||||
|
||||
pub enum PeerState {
|
||||
Connecting(SocketAddr),
|
||||
Live(LivePeerState),
|
||||
}
|
||||
|
||||
pub struct LivePeerState {
|
||||
#[allow(unused)]
|
||||
pub peer_id: [u8; 20],
|
||||
pub i_am_choked: bool,
|
||||
#[allow(unused)]
|
||||
pub peer_choked: bool,
|
||||
#[allow(unused)]
|
||||
pub peer_interested: bool,
|
||||
pub outstanding_requests: Arc<Semaphore>,
|
||||
pub have_notify: Arc<Notify>,
|
||||
pub bitfield: Option<BF>,
|
||||
pub inflight_requests: HashSet<InflightRequest>,
|
||||
}
|
||||
|
|
@ -21,17 +21,11 @@ use crate::{
|
|||
file_checking::update_hash_from_file,
|
||||
lengths::{ChunkInfo, Lengths, ValidPieceIndex},
|
||||
peer_binary_protocol::{Handshake, Message, MessageOwned, Piece},
|
||||
peer_state::{LivePeerState, PeerState},
|
||||
torrent_metainfo::TorrentMetaV1Owned,
|
||||
type_aliases::BF,
|
||||
type_aliases::{PeerHandle, BF},
|
||||
};
|
||||
|
||||
pub type PeerHandle = SocketAddr;
|
||||
|
||||
pub enum PeerState {
|
||||
Connecting(SocketAddr),
|
||||
Live(LivePeerState),
|
||||
}
|
||||
|
||||
#[derive(Debug, Hash, PartialEq, Eq)]
|
||||
pub struct InflightRequest {
|
||||
pub piece: ValidPieceIndex,
|
||||
|
|
@ -47,20 +41,6 @@ impl From<&ChunkInfo> for InflightRequest {
|
|||
}
|
||||
}
|
||||
|
||||
pub struct LivePeerState {
|
||||
#[allow(unused)]
|
||||
pub peer_id: [u8; 20],
|
||||
pub i_am_choked: bool,
|
||||
#[allow(unused)]
|
||||
pub peer_choked: bool,
|
||||
#[allow(unused)]
|
||||
pub peer_interested: bool,
|
||||
pub outstanding_requests: Arc<Semaphore>,
|
||||
pub have_notify: Arc<Notify>,
|
||||
pub bitfield: Option<BF>,
|
||||
pub inflight_requests: HashSet<InflightRequest>,
|
||||
}
|
||||
|
||||
#[derive(Default)]
|
||||
pub struct PeerStates {
|
||||
states: HashMap<PeerHandle, PeerState>,
|
||||
|
|
|
|||
|
|
@ -1 +1,5 @@
|
|||
use std::net::SocketAddr;
|
||||
|
||||
pub type BF = bitvec::vec::BitVec<bitvec::order::Msb0, u8>;
|
||||
|
||||
pub type PeerHandle = SocketAddr;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue