Struct sctp::SctpStream
[−]
[src]
pub struct SctpStream(_);
One-to-one SCTP connected stream which behaves like a TCP stream.
A SctpStream
can be obtained either actively by connecting to a SCTP endpoint with the
connect
constructor, or passively from a SctpListener
which accepts new connections
Methods
impl SctpStream
[src]
fn connect<A: ToSocketAddrs>(address: A) -> Result<SctpStream>
Create a new stream by connecting it to a remote endpoint
fn connectx<A: ToSocketAddrs>(addresses: &[A]) -> Result<SctpStream>
Create a new stream by connecting it to a remote endpoint having multiple addresses
fn sendmsg(&self, msg: &[u8], stream: u16) -> Result<usize>
Send bytes on the specified SCTP stream. On success, returns the quantity of bytes read
fn recvmsg(&self, msg: &mut [u8]) -> Result<(usize, u16)>
Read bytes. On success, return a tuple with the quantity of bytes received and the stream they were recived on
fn local_addrs(&self) -> Result<Vec<SocketAddr>>
Return the list of local socket addresses for this stream
fn peer_addrs(&self) -> Result<Vec<SocketAddr>>
Return the list of socket addresses for the peer this stream is connected to
fn shutdown(&self, how: Shutdown) -> Result<()>
Shuts down the read, write, or both halves of this connection
fn set_nodelay(&self, nodelay: bool) -> Result<()>
Set or unset SCTP_NODELAY option
fn has_nodelay(&self) -> Result<bool>
Verify if SCTP_NODELAY option is activated for this socket
fn set_buffer_size(&self, dir: SoDirection, size: usize) -> Result<()>
Set the socket buffer size for the direction specified by dir
.
Linux systems will double the provided size
fn get_buffer_size(&self, dir: SoDirection) -> Result<usize>
Get the socket buffer size for the direction specified by dir
fn set_timeout(&self, dir: SoDirection, timeout: i32) -> Result<()>
Set timeout
in seconds for operation dir
(either receive or send)
fn try_clone(&self) -> Result<SctpStream>
Try to clone the SctpStream. On success, returns a new stream wrapping a new socket handler
Trait Implementations
impl Read for SctpStream
[src]
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
1.0.0
Read all bytes until EOF in this source, placing them into buf
. Read more
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
1.0.0
Read all bytes until EOF in this source, placing them into buf
. Read more
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
1.6.0
Read the exact number of bytes required to fill buf
. Read more
fn by_ref(&mut self) -> &mut Self
1.0.0
Creates a "by reference" adaptor for this instance of Read
. Read more
fn bytes(self) -> Bytes<Self>
1.0.0
Transforms this Read
instance to an Iterator
over its bytes. Read more
fn chars(self) -> Chars<Self>
🔬 This is a nightly-only experimental API. (io
)
the semantics of a partial read/write of where errors happen is currently unclear and may change
Transforms this Read
instance to an Iterator
over char
s. Read more
fn chain<R>(self, next: R) -> Chain<Self, R> where
R: Read,
1.0.0
R: Read,
Creates an adaptor which will chain this stream with another. Read more
fn take(self, limit: u64) -> Take<Self>
1.0.0
Creates an adaptor which will read at most limit
bytes from it. Read more
impl Write for SctpStream
[src]
fn write(&mut self, buf: &[u8]) -> Result<usize>
Write a buffer into this object, returning how many bytes were written. Read more
fn flush(&mut self) -> Result<()>
Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
1.0.0
Attempts to write an entire buffer into this write. Read more
fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>
1.0.0
Writes a formatted string into this writer, returning any error encountered. Read more
fn by_ref(&mut self) -> &mut Self
1.0.0
Creates a "by reference" adaptor for this instance of Write
. Read more
impl AsRawFd for SctpStream
[src]
impl FromRawFd for SctpStream
[src]
unsafe fn from_raw_fd(fd: RawFd) -> SctpStream
Constructs a new instance of Self
from the given raw file descriptor. Read more