move where the modifier is
This commit is contained in:
parent
5a849a87c7
commit
664625402f
|
@ -259,7 +259,7 @@ wrap_methods! { GenericCommand;
|
||||||
/// The [GenericCommand] gets consumed.
|
/// The [GenericCommand] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns tag [CommandTag::Invalid] in case of an error.
|
/// Returns tag [CommandTag::Invalid] in case of an error.
|
||||||
move fn try_into_packet(command) -> *mut Packet {
|
fn try_into_packet(move command) -> *mut Packet {
|
||||||
match command.tag {
|
match command.tag {
|
||||||
CommandTag::Invalid => null_mut(),
|
CommandTag::Invalid => null_mut(),
|
||||||
CommandTag::Bitmap => {
|
CommandTag::Bitmap => {
|
||||||
|
|
|
@ -71,7 +71,7 @@ macro_rules! derive_command_into_packet {
|
||||||
#[doc = "Tries to turn a [`" $command_type "`] into a [Packet]."]
|
#[doc = "Tries to turn a [`" $command_type "`] into a [Packet]."]
|
||||||
///
|
///
|
||||||
/// Returns: NULL or a [Packet] containing the command.
|
/// Returns: NULL or a [Packet] containing the command.
|
||||||
move fn try_into_packet(instance) -> *mut ::servicepoint::Packet {
|
fn try_into_packet(move instance) -> *mut ::servicepoint::Packet {
|
||||||
$crate::mem::heap_move_ok(instance.try_into())
|
$crate::mem::heap_move_ok(instance.try_into())
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
|
@ -79,7 +79,7 @@ wrap_functions!(associate Bitmap;
|
||||||
|
|
||||||
wrap_methods!(Bitmap;
|
wrap_methods!(Bitmap;
|
||||||
/// Consumes the Bitmap and returns the contained BitVec.
|
/// Consumes the Bitmap and returns the contained BitVec.
|
||||||
move fn into_bitvec(bitmap) -> NonNull<DisplayBitVec> {
|
fn into_bitvec(move bitmap) -> NonNull<DisplayBitVec> {
|
||||||
heap_move_nonnull(bitmap.into())
|
heap_move_nonnull(bitmap.into())
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ wrap_methods!(Bitmap;
|
||||||
/// The provided [Bitmap] gets consumed.
|
/// The provided [Bitmap] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns NULL in case of an error.
|
/// Returns NULL in case of an error.
|
||||||
move fn try_into_packet(bitmap, x: usize, y: usize, compression: CompressionCode) -> *mut Packet {
|
fn try_into_packet(move bitmap, x: usize, y: usize, compression: CompressionCode) -> *mut Packet {
|
||||||
heap_move_ok(Packet::try_from(BitmapCommand {
|
heap_move_ok(Packet::try_from(BitmapCommand {
|
||||||
bitmap,
|
bitmap,
|
||||||
origin: Origin::new(x, y),
|
origin: Origin::new(x, y),
|
||||||
|
@ -99,7 +99,7 @@ wrap_methods!(Bitmap;
|
||||||
/// Gets an unsafe reference to the data of the [Bitmap] instance.
|
/// Gets an unsafe reference to the data of the [Bitmap] instance.
|
||||||
///
|
///
|
||||||
/// The returned memory is valid for the lifetime of the bitmap.
|
/// The returned memory is valid for the lifetime of the bitmap.
|
||||||
mut fn data_ref_mut(instance) -> ByteSlice {
|
fn data_ref_mut(mut instance) -> ByteSlice {
|
||||||
unsafe { ByteSlice::from_slice(instance.data_ref_mut()) }
|
unsafe { ByteSlice::from_slice(instance.data_ref_mut()) }
|
||||||
};
|
};
|
||||||
);
|
);
|
||||||
|
|
|
@ -43,8 +43,8 @@ wrap_methods!(DisplayBitVec;
|
||||||
/// The provided [DisplayBitVec] gets consumed.
|
/// The provided [DisplayBitVec] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns NULL in case of an error.
|
/// Returns NULL in case of an error.
|
||||||
move fn try_into_packet(
|
fn try_into_packet(
|
||||||
bitvec,
|
move bitvec,
|
||||||
offset: usize,
|
offset: usize,
|
||||||
operation: BinaryOperation,
|
operation: BinaryOperation,
|
||||||
compression: CompressionCode
|
compression: CompressionCode
|
||||||
|
@ -69,7 +69,7 @@ wrap_methods!(DisplayBitVec;
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// - when accessing `index` out of bounds
|
/// - when accessing `index` out of bounds
|
||||||
ref fn get(instance, index: usize) -> bool {
|
fn get(ref instance, index: usize) -> bool {
|
||||||
instance.get(index).map(|x| *x).unwrap_or(false)
|
instance.get(index).map(|x| *x).unwrap_or(false)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -83,25 +83,25 @@ wrap_methods!(DisplayBitVec;
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// - when accessing `index` out of bounds
|
/// - when accessing `index` out of bounds
|
||||||
mut fn set(instance, index: usize, value: bool);
|
fn set(mut instance, index: usize, value: bool);
|
||||||
|
|
||||||
/// Sets the value of all bits.
|
/// Sets the value of all bits.
|
||||||
///
|
///
|
||||||
/// # Arguments
|
/// # Arguments
|
||||||
///
|
///
|
||||||
/// - `value`: the value to set all bits to
|
/// - `value`: the value to set all bits to
|
||||||
mut fn fill(instance, value: bool);
|
fn fill(mut instance, value: bool);
|
||||||
|
|
||||||
/// Gets the length in bits.
|
/// Gets the length in bits.
|
||||||
ref fn len(instance) -> usize;
|
fn len(ref instance) -> usize;
|
||||||
|
|
||||||
/// Returns true if length is 0.
|
/// Returns true if length is 0.
|
||||||
ref fn is_empty(instance) -> bool;
|
fn is_empty(ref instance) -> bool;
|
||||||
|
|
||||||
/// Gets an unsafe reference to the data of the [DisplayBitVec] instance.
|
/// Gets an unsafe reference to the data of the [DisplayBitVec] instance.
|
||||||
///
|
///
|
||||||
/// The returned memory is valid for the lifetime of the bitvec.
|
/// The returned memory is valid for the lifetime of the bitvec.
|
||||||
mut fn as_raw_mut_slice(instance) -> ByteSlice {
|
fn as_raw_mut_slice(mut instance) -> ByteSlice {
|
||||||
unsafe { ByteSlice::from_slice(instance.as_raw_mut_slice()) }
|
unsafe { ByteSlice::from_slice(instance.as_raw_mut_slice()) }
|
||||||
};
|
};
|
||||||
);
|
);
|
||||||
|
|
|
@ -62,7 +62,7 @@ wrap_methods!(BrightnessGrid;
|
||||||
/// The provided [BrightnessGrid] gets consumed.
|
/// The provided [BrightnessGrid] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns NULL in case of an error.
|
/// Returns NULL in case of an error.
|
||||||
move fn try_into_packet(grid, x: usize, y: usize) -> *mut Packet {
|
fn try_into_packet(move grid, x: usize, y: usize) -> *mut Packet {
|
||||||
heap_move_ok(Packet::try_from(BrightnessGridCommand {
|
heap_move_ok(Packet::try_from(BrightnessGridCommand {
|
||||||
grid,
|
grid,
|
||||||
origin: Origin::new(x, y),
|
origin: Origin::new(x, y),
|
||||||
|
@ -72,7 +72,7 @@ wrap_methods!(BrightnessGrid;
|
||||||
/// Gets an unsafe reference to the data of the instance.
|
/// Gets an unsafe reference to the data of the instance.
|
||||||
///
|
///
|
||||||
/// The returned memory is valid for the lifetime of the grid.
|
/// The returned memory is valid for the lifetime of the grid.
|
||||||
mut fn data_ref_mut(instance) -> ByteSlice {
|
fn data_ref_mut(mut instance) -> ByteSlice {
|
||||||
//noinspection RsAssertEqual
|
//noinspection RsAssertEqual
|
||||||
const _: () = assert!(size_of::<Brightness>() == 1);
|
const _: () = assert!(size_of::<Brightness>() == 1);
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@ wrap_methods!(CharGrid;
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// - when accessing `x` or `y` out of bounds
|
/// - when accessing `x` or `y` out of bounds
|
||||||
ref fn get(instance, x: usize, y: usize) -> u32 {
|
fn get(ref instance, x: usize, y: usize) -> u32 {
|
||||||
instance.get(x, y) as u32
|
instance.get(x, y) as u32
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ wrap_methods!(CharGrid;
|
||||||
///
|
///
|
||||||
/// - when accessing `x` or `y` out of bounds
|
/// - when accessing `x` or `y` out of bounds
|
||||||
/// - when providing values that cannot be converted to Rust's `char`.
|
/// - when providing values that cannot be converted to Rust's `char`.
|
||||||
mut fn set(instance, x: usize, y: usize, value: u32) {
|
fn set(mut instance, x: usize, y: usize, value: u32) {
|
||||||
instance.set(x, y, char::from_u32(value).unwrap())
|
instance.set(x, y, char::from_u32(value).unwrap())
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ wrap_methods!(CharGrid;
|
||||||
///
|
///
|
||||||
/// - `value`: the value to set all cells to
|
/// - `value`: the value to set all cells to
|
||||||
/// - when providing values that cannot be converted to Rust's `char`.
|
/// - when providing values that cannot be converted to Rust's `char`.
|
||||||
mut fn fill(instance, value: u32) {
|
fn fill(mut instance, value: u32) {
|
||||||
instance.fill(char::from_u32(value).unwrap())
|
instance.fill(char::from_u32(value).unwrap())
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ wrap_methods!(CharGrid;
|
||||||
/// The provided [CharGrid] gets consumed.
|
/// The provided [CharGrid] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns NULL in case of an error.
|
/// Returns NULL in case of an error.
|
||||||
move fn try_into_packet(grid, x: usize, y: usize) -> *mut Packet {
|
fn try_into_packet(move grid, x: usize, y: usize) -> *mut Packet {
|
||||||
heap_move_ok(Packet::try_from(CharGridCommand {
|
heap_move_ok(Packet::try_from(CharGridCommand {
|
||||||
grid,
|
grid,
|
||||||
origin: Origin::new(x, y),
|
origin: Origin::new(x, y),
|
||||||
|
|
|
@ -31,7 +31,7 @@ wrap_methods!(Cp437Grid;
|
||||||
/// The provided [Cp437Grid] gets consumed.
|
/// The provided [Cp437Grid] gets consumed.
|
||||||
///
|
///
|
||||||
/// Returns NULL in case of an error.
|
/// Returns NULL in case of an error.
|
||||||
move fn try_into_packet(grid, x: usize, y: usize) -> *mut Packet {
|
fn try_into_packet(move grid, x: usize, y: usize) -> *mut Packet {
|
||||||
heap_move_ok(Packet::try_from(Cp437GridCommand {
|
heap_move_ok(Packet::try_from(Cp437GridCommand {
|
||||||
grid,
|
grid,
|
||||||
origin: Origin::new(x, y),
|
origin: Origin::new(x, y),
|
||||||
|
@ -41,7 +41,7 @@ wrap_methods!(Cp437Grid;
|
||||||
/// Gets an unsafe reference to the data of the grid.
|
/// Gets an unsafe reference to the data of the grid.
|
||||||
///
|
///
|
||||||
/// The returned memory is valid for the lifetime of the instance.
|
/// The returned memory is valid for the lifetime of the instance.
|
||||||
mut fn data_ref_mut(instance) -> ByteSlice {
|
fn data_ref_mut(mut instance) -> ByteSlice {
|
||||||
unsafe { ByteSlice::from_slice(instance.data_ref_mut()) }
|
unsafe { ByteSlice::from_slice(instance.data_ref_mut()) }
|
||||||
};
|
};
|
||||||
);
|
);
|
||||||
|
|
|
@ -23,10 +23,10 @@ macro_rules! derive_get_width_height {
|
||||||
($object_type:ident) => {
|
($object_type:ident) => {
|
||||||
$crate::macros::wrap_methods! {$object_type;
|
$crate::macros::wrap_methods! {$object_type;
|
||||||
/// Gets the width.
|
/// Gets the width.
|
||||||
ref fn width(instance) -> usize;
|
fn width(ref instance) -> usize;
|
||||||
|
|
||||||
/// Gets the height.
|
/// Gets the height.
|
||||||
ref fn height(instance) -> usize;
|
fn height(ref instance) -> usize;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ macro_rules! wrap_grid {
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// - when accessing `x` or `y` out of bounds
|
/// - when accessing `x` or `y` out of bounds
|
||||||
ref fn get(instance, x: usize, y: usize) -> $value_type;
|
fn get(ref instance, x: usize, y: usize) -> $value_type;
|
||||||
|
|
||||||
/// Sets the value of the specified position.
|
/// Sets the value of the specified position.
|
||||||
///
|
///
|
||||||
|
@ -57,14 +57,14 @@ macro_rules! wrap_grid {
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
/// - when accessing `x` or `y` out of bounds
|
/// - when accessing `x` or `y` out of bounds
|
||||||
mut fn set(instance, x: usize, y: usize, value: $value_type);
|
fn set(mut instance, x: usize, y: usize, value: $value_type);
|
||||||
|
|
||||||
/// Sets the state of all cells in the grid.
|
/// Sets the state of all cells in the grid.
|
||||||
///
|
///
|
||||||
/// # Arguments
|
/// # Arguments
|
||||||
///
|
///
|
||||||
/// - `value`: the value to set all cells to
|
/// - `value`: the value to set all cells to
|
||||||
mut fn fill(instance, value: $value_type);
|
fn fill(mut instance, value: $value_type);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,14 +46,14 @@ macro_rules! wrap_method {
|
||||||
(
|
(
|
||||||
$object_type:ident;
|
$object_type:ident;
|
||||||
$(#[$meta:meta])+
|
$(#[$meta:meta])+
|
||||||
$ref_or_mut:ident fn $function:ident($instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
fn $function:ident($ref_or_mut:ident $instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
||||||
$(-> $return_type:ty)?
|
$(-> $return_type:ty)?
|
||||||
) => {
|
) => {
|
||||||
::paste::paste!{
|
::paste::paste!{
|
||||||
$crate::macros::wrap_method!(
|
$crate::macros::wrap_method!(
|
||||||
$object_type;
|
$object_type;
|
||||||
$(#[$meta])+
|
$(#[$meta])+
|
||||||
$ref_or_mut fn $function($instance $(, $($param_name: $param_type),*)?)
|
fn $function($ref_or_mut $instance $(, $($param_name: $param_type),*)?)
|
||||||
$(-> $return_type)? {
|
$(-> $return_type)? {
|
||||||
$instance.$function($($($param_name),*)?)
|
$instance.$function($($($param_name),*)?)
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ macro_rules! wrap_method {
|
||||||
};
|
};
|
||||||
($object_type:ident;
|
($object_type:ident;
|
||||||
$(#[$meta:meta])+
|
$(#[$meta:meta])+
|
||||||
$ref_or_mut:ident fn $function:ident($instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
fn $function:ident($ref_or_mut:ident $instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
||||||
$(-> $return_type:ty)?
|
$(-> $return_type:ty)?
|
||||||
$impl:block
|
$impl:block
|
||||||
) => {
|
) => {
|
||||||
|
@ -88,7 +88,7 @@ macro_rules! wrap_methods {
|
||||||
$object_type:ident;
|
$object_type:ident;
|
||||||
$(
|
$(
|
||||||
$(#[$meta:meta])+
|
$(#[$meta:meta])+
|
||||||
$ref_or_mut:ident fn $function:ident($instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
fn $function:ident($ref_or_mut:ident $instance:ident $(, $($param_name:ident: $param_type:ty),*)?)
|
||||||
$(-> $return_type:ty)?
|
$(-> $return_type:ty)?
|
||||||
$($impl:block)?;
|
$($impl:block)?;
|
||||||
)+
|
)+
|
||||||
|
@ -97,7 +97,7 @@ macro_rules! wrap_methods {
|
||||||
$(
|
$(
|
||||||
$crate::macros::wrap_method!($object_type;
|
$crate::macros::wrap_method!($object_type;
|
||||||
$(#[$meta])*
|
$(#[$meta])*
|
||||||
$ref_or_mut fn $function($instance $(, $($param_name: $param_type),*)?)
|
fn $function($ref_or_mut $instance $(, $($param_name: $param_type),*)?)
|
||||||
$(-> $return_type)?
|
$(-> $return_type)?
|
||||||
$($impl)?
|
$($impl)?
|
||||||
);
|
);
|
||||||
|
|
|
@ -57,7 +57,7 @@ wrap_methods! {UdpSocket;
|
||||||
/// The passed `packet` gets consumed.
|
/// The passed `packet` gets consumed.
|
||||||
///
|
///
|
||||||
/// returns: true in case of success
|
/// returns: true in case of success
|
||||||
ref fn send_packet(connection, packet: NonNull<Packet>) -> bool {
|
fn send_packet(ref connection, packet: NonNull<Packet>) -> bool {
|
||||||
let packet = unsafe { heap_remove(packet) };
|
let packet = unsafe { heap_remove(packet) };
|
||||||
connection.send(&Vec::from(packet)).is_ok()
|
connection.send(&Vec::from(packet)).is_ok()
|
||||||
};
|
};
|
||||||
|
@ -73,7 +73,7 @@ wrap_methods! {UdpSocket;
|
||||||
/// ```C
|
/// ```C
|
||||||
/// sp_udp_send_command(connection, sp_command_brightness(5));
|
/// sp_udp_send_command(connection, sp_command_brightness(5));
|
||||||
/// ```
|
/// ```
|
||||||
ref fn send_command(connection, command: NonNull<GenericCommand>) -> bool {
|
fn send_command(ref connection, command: NonNull<GenericCommand>) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let command = crate::macros::nonnull_as_mut!(command);
|
let command = crate::macros::nonnull_as_mut!(command);
|
||||||
let result = match command.tag {
|
let result = match command.tag {
|
||||||
|
@ -103,7 +103,7 @@ wrap_methods! {UdpSocket;
|
||||||
/// ```C
|
/// ```C
|
||||||
/// sp_udp_send_header(connection, sp_command_brightness(5));
|
/// sp_udp_send_header(connection, sp_command_brightness(5));
|
||||||
/// ```
|
/// ```
|
||||||
ref fn send_header(udp_connection, header: Header) -> bool {
|
fn send_header(ref udp_connection, header: Header) -> bool {
|
||||||
let packet = Packet {
|
let packet = Packet {
|
||||||
header,
|
header,
|
||||||
payload: None,
|
payload: None,
|
||||||
|
|
Loading…
Reference in a new issue