Struct serialport::COMPort

source ·
pub struct COMPort { /* private fields */ }
Expand description

A serial port implementation for Windows COM ports

The port will be closed when the value is dropped. However, this struct should not be instantiated directly by using COMPort::open(), instead use the cross-platform serialport::open() or serialport::open_with_settings().

Implementations§

source§

impl COMPort

source

pub fn open(builder: &SerialPortBuilder) -> Result<COMPort>

Opens a COM port as a serial device.

port should be the name of a COM port, e.g., COM1.

If the COM port handle needs to be opened with special flags, use from_raw_handle method to create the COMPort. Note that you should set the different settings before using the serial port using set_all.

Errors
  • NoDevice if the device could not be opened. This could indicate that the device is already in use.
  • InvalidInput if port is not a valid device name.
  • Io for any other I/O error while opening or initializing the device.
source

pub fn try_clone_native(&self) -> Result<COMPort>

Attempts to clone the SerialPort. This allow you to write and read simultaneously from the same serial connection. Please note that if you want a real asynchronous serial port you should look at mio-serial or tokio-serial.

Also, you must be very careful when changing the settings of a cloned SerialPort : since the settings are cached on a per object basis, trying to modify them from two different objects can cause some nasty behavior.

This is the same as SerialPort::try_clone() but returns the concrete type instead.

Errors

This function returns an error if the serial port couldn’t be cloned.

Trait Implementations§

source§

impl AsRawHandle for COMPort

source§

fn as_raw_handle(&self) -> RawHandle

Extracts the raw handle. Read more
source§

impl Debug for COMPort

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Drop for COMPort

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl FromRawHandle for COMPort

source§

unsafe fn from_raw_handle(handle: RawHandle) -> Self

Constructs a new I/O object from the specified raw handle. Read more
source§

impl Read for COMPort

source§

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
1.36.0 · source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · source§

fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>

Read all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Read all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

Read the exact number of bytes required to fill buf. Read more
source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

fn chain<R>(self, next: R) -> Chain<Self, R>where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

fn take(self, limit: u64) -> Take<Self>where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more
source§

impl SerialPort for COMPort

source§

fn name(&self) -> Option<String>

Returns the name of this port if it exists. Read more
source§

fn timeout(&self) -> Duration

Returns the current timeout.
source§

fn set_timeout(&mut self, timeout: Duration) -> Result<()>

Sets the timeout for future I/O operations.
source§

fn write_request_to_send(&mut self, level: bool) -> Result<()>

Sets the state of the RTS (Request To Send) control signal. Read more
source§

fn write_data_terminal_ready(&mut self, level: bool) -> Result<()>

Writes to the Data Terminal Ready pin Read more
source§

fn read_clear_to_send(&mut self) -> Result<bool>

Reads the state of the CTS (Clear To Send) control signal. Read more
source§

fn read_data_set_ready(&mut self) -> Result<bool>

Reads the state of the Data Set Ready control signal. Read more
source§

fn read_ring_indicator(&mut self) -> Result<bool>

Reads the state of the Ring Indicator control signal. Read more
source§

fn read_carrier_detect(&mut self) -> Result<bool>

Reads the state of the Carrier Detect control signal. Read more
source§

fn baud_rate(&self) -> Result<u32>

Returns the current baud rate. Read more
source§

fn data_bits(&self) -> Result<DataBits>

Returns the character size. Read more
source§

fn parity(&self) -> Result<Parity>

Returns the parity-checking mode. Read more
source§

fn stop_bits(&self) -> Result<StopBits>

Returns the number of stop bits. Read more
source§

fn flow_control(&self) -> Result<FlowControl>

Returns the flow control mode. Read more
source§

fn set_baud_rate(&mut self, baud_rate: u32) -> Result<()>

Sets the baud rate. Read more
source§

fn set_data_bits(&mut self, data_bits: DataBits) -> Result<()>

Sets the character size.
source§

fn set_parity(&mut self, parity: Parity) -> Result<()>

Sets the parity-checking mode.
source§

fn set_stop_bits(&mut self, stop_bits: StopBits) -> Result<()>

Sets the number of stop bits.
source§

fn set_flow_control(&mut self, flow_control: FlowControl) -> Result<()>

Sets the flow control mode.
source§

fn bytes_to_read(&self) -> Result<u32>

Gets the number of bytes available to be read from the input buffer. Read more
source§

fn bytes_to_write(&self) -> Result<u32>

Get the number of bytes written to the output buffer, awaiting transmission. Read more
source§

fn clear(&self, buffer_to_clear: ClearBuffer) -> Result<()>

Discards all bytes from the serial driver’s input buffer and/or output buffer. Read more
source§

fn try_clone(&self) -> Result<Box<dyn SerialPort>>

Attempts to clone the SerialPort. This allow you to write and read simultaneously from the same serial connection. Please note that if you want a real asynchronous serial port you should look at mio-serial or tokio-serial. Read more
source§

fn set_break(&self) -> Result<()>

Start transmitting a break
source§

fn clear_break(&self) -> Result<()>

Stop transmitting a break
source§

impl Write for COMPort

source§

fn write(&mut self, buf: &[u8]) -> Result<usize>

Write a buffer into this writer, returning how many bytes were written. Read more
source§

fn flush(&mut self) -> Result<()>

Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
1.36.0 · source§

fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> Result<usize, Error>

Like write, except that it writes from a slice of buffers. Read more
source§

fn is_write_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Writer has an efficient write_vectored implementation. Read more
1.0.0 · source§

fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>

Attempts to write an entire buffer into this writer. Read more
source§

fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>

🔬This is a nightly-only experimental API. (write_all_vectored)
Attempts to write multiple buffers into this writer. Read more
1.0.0 · source§

fn write_fmt(&mut self, fmt: Arguments<'_>) -> Result<(), Error>

Writes a formatted string into this writer, returning any error encountered. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Creates a “by reference” adapter for this instance of Write. Read more
source§

impl Send for COMPort

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.