Enum Command

Source
pub enum Command {
    ExitSafeStart,
    MotorFwd {
        speed: u16,
    },
    MotorRev {
        speed: u16,
    },
    MotorFwd7bit {
        speed: u8,
    },
    MotorRev7bit {
        speed: u8,
    },
    MotorBrake {
        brake_amount: u8,
    },
    SetCurrentLimit {
        value: u16,
    },
    StopMotor,
}
Expand description

Representations of the commands that can be sent to the controller.

These only contain the commands which do not provide any response, which can thus be used in [SimpleMotorController::send_command]. There are some additional commands available that do provide a response. These are handled separately by the methods [SimpleMotorController::set_motor_limit] and [SimpleMotorController::get_firmware_version].

Variants§

§

ExitSafeStart

If safe-start protection is enabled, this command is required before the motor can run.

§

MotorFwd

Sets the full-resolution motor target speed in the forward direction.

Fields

§speed: u16

Target speed, 0 (motor stopped) to 3200 (full speed).

§

MotorRev

Sets the full-resolution motor target speed in the reverse direction.

Fields

§speed: u16

Target speed, 0 (motor stopped) to 3200 (full speed).

§

MotorFwd7bit

Sets the low-resolution motor target speed in the forward direction.

Fields

§speed: u8

Target speed, 0 (motor stopped) to 127 (full speed).

§

MotorRev7bit

Sets the low-resolution motor target speed in the reverse direction.

Fields

§speed: u8

Target speed, 0 (motor stopped) to 127 (full speed).

§

MotorBrake

Causes the motor to immediately brake or coast (configured deceleration limits are ignored).

Fields

§brake_amount: u8

The amount of braking action. 0 (coasting) to 32.

§

SetCurrentLimit

This command lets you change the hardware current limit temporarily until the next reset.

Fields

§value: u16

The current limit in internal units. See section 5.2 in the official user’s guide for instructions on how to convert mA into these internal units.

§

StopMotor

Sets the motor target speed to zero, stopping the motor respecting the configured deceleration limits. This also makes the controller susceptible to a safe-start violation error is safe-start is enabled.

Trait Implementations§

Source§

impl Clone for Command

Source§

fn clone(&self) -> Command

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Command

Source§

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

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

impl Hash for Command

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for Command

Source§

fn cmp(&self, other: &Command) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for Command

Source§

fn eq(&self, other: &Command) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for Command

Source§

fn partial_cmp(&self, other: &Command) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Copy for Command

Source§

impl Eq for Command

Source§

impl StructuralPartialEq for Command

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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 T
where 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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.