#![allow(clippy::too_many_arguments)]
#![allow(clippy::useless_conversion)]
#[allow(unused_imports)]
use alloc::borrow::Cow;
#[allow(unused_imports)]
use core::convert::TryInto;
use alloc::vec;
use alloc::vec::Vec;
use core::convert::TryFrom;
use crate::errors::ParseError;
#[allow(unused_imports)]
use crate::x11_utils::TryIntoUSize;
use crate::BufWithFds;
#[allow(unused_imports)]
use crate::utils::{RawFdContainer, pretty_print_bitmask, pretty_print_enum};
#[allow(unused_imports)]
use crate::x11_utils::{Request, RequestHeader, Serialize, TryParse, TryParseFd};
pub const X11_EXTENSION_NAME: &str = "XFree86-VidModeExtension";
pub const X11_XML_VERSION: (u32, u32) = (2, 2);
pub type Syncrange = u32;
pub type Dotclock = u32;
#[derive(Clone, Copy, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ModeFlag(u32);
impl ModeFlag {
pub const POSITIVE_H_SYNC: Self = Self(1 << 0);
pub const NEGATIVE_H_SYNC: Self = Self(1 << 1);
pub const POSITIVE_V_SYNC: Self = Self(1 << 2);
pub const NEGATIVE_V_SYNC: Self = Self(1 << 3);
pub const INTERLACE: Self = Self(1 << 4);
pub const COMPOSITE_SYNC: Self = Self(1 << 5);
pub const POSITIVE_C_SYNC: Self = Self(1 << 6);
pub const NEGATIVE_C_SYNC: Self = Self(1 << 7);
pub const H_SKEW: Self = Self(1 << 8);
pub const BROADCAST: Self = Self(1 << 9);
pub const PIXMUX: Self = Self(1 << 10);
pub const DOUBLE_CLOCK: Self = Self(1 << 11);
pub const HALF_CLOCK: Self = Self(1 << 12);
}
impl From<ModeFlag> for u32 {
#[inline]
fn from(input: ModeFlag) -> Self {
input.0
}
}
impl From<ModeFlag> for Option<u32> {
#[inline]
fn from(input: ModeFlag) -> Self {
Some(input.0)
}
}
impl From<u8> for ModeFlag {
#[inline]
fn from(value: u8) -> Self {
Self(value.into())
}
}
impl From<u16> for ModeFlag {
#[inline]
fn from(value: u16) -> Self {
Self(value.into())
}
}
impl From<u32> for ModeFlag {
#[inline]
fn from(value: u32) -> Self {
Self(value)
}
}
impl core::fmt::Debug for ModeFlag {
fn fmt(&self, fmt: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
let variants = [
(Self::POSITIVE_H_SYNC.0, "POSITIVE_H_SYNC", "PositiveHSync"),
(Self::NEGATIVE_H_SYNC.0, "NEGATIVE_H_SYNC", "NegativeHSync"),
(Self::POSITIVE_V_SYNC.0, "POSITIVE_V_SYNC", "PositiveVSync"),
(Self::NEGATIVE_V_SYNC.0, "NEGATIVE_V_SYNC", "NegativeVSync"),
(Self::INTERLACE.0, "INTERLACE", "Interlace"),
(Self::COMPOSITE_SYNC.0, "COMPOSITE_SYNC", "CompositeSync"),
(Self::POSITIVE_C_SYNC.0, "POSITIVE_C_SYNC", "PositiveCSync"),
(Self::NEGATIVE_C_SYNC.0, "NEGATIVE_C_SYNC", "NegativeCSync"),
(Self::H_SKEW.0, "H_SKEW", "HSkew"),
(Self::BROADCAST.0, "BROADCAST", "Broadcast"),
(Self::PIXMUX.0, "PIXMUX", "Pixmux"),
(Self::DOUBLE_CLOCK.0, "DOUBLE_CLOCK", "DoubleClock"),
(Self::HALF_CLOCK.0, "HALF_CLOCK", "HalfClock"),
];
pretty_print_bitmask(fmt, self.0, &variants)
}
}
bitmask_binop!(ModeFlag, u32);
#[derive(Clone, Copy, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ClockFlag(u32);
impl ClockFlag {
pub const PROGRAMABLE: Self = Self(1 << 0);
}
impl From<ClockFlag> for u32 {
#[inline]
fn from(input: ClockFlag) -> Self {
input.0
}
}
impl From<ClockFlag> for Option<u32> {
#[inline]
fn from(input: ClockFlag) -> Self {
Some(input.0)
}
}
impl From<u8> for ClockFlag {
#[inline]
fn from(value: u8) -> Self {
Self(value.into())
}
}
impl From<u16> for ClockFlag {
#[inline]
fn from(value: u16) -> Self {
Self(value.into())
}
}
impl From<u32> for ClockFlag {
#[inline]
fn from(value: u32) -> Self {
Self(value)
}
}
impl core::fmt::Debug for ClockFlag {
fn fmt(&self, fmt: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
let variants = [
(Self::PROGRAMABLE.0, "PROGRAMABLE", "Programable"),
];
pretty_print_bitmask(fmt, self.0, &variants)
}
}
bitmask_binop!(ClockFlag, u32);
#[derive(Clone, Copy, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct Permission(u32);
impl Permission {
pub const READ: Self = Self(1 << 0);
pub const WRITE: Self = Self(1 << 1);
}
impl From<Permission> for u32 {
#[inline]
fn from(input: Permission) -> Self {
input.0
}
}
impl From<Permission> for Option<u32> {
#[inline]
fn from(input: Permission) -> Self {
Some(input.0)
}
}
impl From<u8> for Permission {
#[inline]
fn from(value: u8) -> Self {
Self(value.into())
}
}
impl From<u16> for Permission {
#[inline]
fn from(value: u16) -> Self {
Self(value.into())
}
}
impl From<u32> for Permission {
#[inline]
fn from(value: u32) -> Self {
Self(value)
}
}
impl core::fmt::Debug for Permission {
fn fmt(&self, fmt: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
let variants = [
(Self::READ.0, "READ", "Read"),
(Self::WRITE.0, "WRITE", "Write"),
];
pretty_print_bitmask(fmt, self.0, &variants)
}
}
bitmask_binop!(Permission, u32);
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ModeInfo {
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u32,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub privsize: u32,
}
impl_debug_if_no_extra_traits!(ModeInfo, "ModeInfo");
impl TryParse for ModeInfo {
fn try_parse(remaining: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u32::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(4..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let result = ModeInfo { dotclock, hdisplay, hsyncstart, hsyncend, htotal, hskew, vdisplay, vsyncstart, vsyncend, vtotal, flags, privsize };
Ok((result, remaining))
}
}
impl Serialize for ModeInfo {
type Bytes = [u8; 48];
fn serialize(&self) -> [u8; 48] {
let dotclock_bytes = self.dotclock.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize_bytes = self.privsize.serialize();
[
dotclock_bytes[0],
dotclock_bytes[1],
dotclock_bytes[2],
dotclock_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
hskew_bytes[2],
hskew_bytes[3],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(48);
self.dotclock.serialize_into(bytes);
self.hdisplay.serialize_into(bytes);
self.hsyncstart.serialize_into(bytes);
self.hsyncend.serialize_into(bytes);
self.htotal.serialize_into(bytes);
self.hskew.serialize_into(bytes);
self.vdisplay.serialize_into(bytes);
self.vsyncstart.serialize_into(bytes);
self.vsyncend.serialize_into(bytes);
self.vtotal.serialize_into(bytes);
bytes.extend_from_slice(&[0; 4]);
u32::from(self.flags).serialize_into(bytes);
bytes.extend_from_slice(&[0; 12]);
self.privsize.serialize_into(bytes);
}
}
pub const QUERY_VERSION_REQUEST: u8 = 0;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct QueryVersionRequest;
impl_debug_if_no_extra_traits!(QueryVersionRequest, "QueryVersionRequest");
impl QueryVersionRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let mut request0 = vec![
major_opcode,
QUERY_VERSION_REQUEST,
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != QUERY_VERSION_REQUEST {
return Err(ParseError::InvalidValue);
}
let _ = value;
Ok(QueryVersionRequest
)
}
}
impl Request for QueryVersionRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for QueryVersionRequest {
type Reply = QueryVersionReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct QueryVersionReply {
pub sequence: u16,
pub length: u32,
pub major_version: u16,
pub minor_version: u16,
}
impl_debug_if_no_extra_traits!(QueryVersionReply, "QueryVersionReply");
impl TryParse for QueryVersionReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (major_version, remaining) = u16::try_parse(remaining)?;
let (minor_version, remaining) = u16::try_parse(remaining)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = QueryVersionReply { sequence, length, major_version, minor_version };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for QueryVersionReply {
type Bytes = [u8; 12];
fn serialize(&self) -> [u8; 12] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let major_version_bytes = self.major_version.serialize();
let minor_version_bytes = self.minor_version.serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
major_version_bytes[0],
major_version_bytes[1],
minor_version_bytes[0],
minor_version_bytes[1],
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(12);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.major_version.serialize_into(bytes);
self.minor_version.serialize_into(bytes);
}
}
pub const GET_MODE_LINE_REQUEST: u8 = 1;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetModeLineRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetModeLineRequest, "GetModeLineRequest");
impl GetModeLineRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_MODE_LINE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_MODE_LINE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetModeLineRequest {
screen,
})
}
}
impl Request for GetModeLineRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetModeLineRequest {
type Reply = GetModeLineReply;
}
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetModeLineReply {
pub sequence: u16,
pub length: u32,
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub private: Vec<u8>,
}
impl_debug_if_no_extra_traits!(GetModeLineReply, "GetModeLineReply");
impl TryParse for GetModeLineReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let private = private.to_vec();
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let flags = flags.into();
let result = GetModeLineReply { sequence, length, dotclock, hdisplay, hsyncstart, hsyncend, htotal, hskew, vdisplay, vsyncstart, vsyncend, vtotal, flags, private };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetModeLineReply {
type Bytes = Vec<u8>;
fn serialize(&self) -> Vec<u8> {
let mut result = Vec::new();
self.serialize_into(&mut result);
result
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(52);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.dotclock.serialize_into(bytes);
self.hdisplay.serialize_into(bytes);
self.hsyncstart.serialize_into(bytes);
self.hsyncend.serialize_into(bytes);
self.htotal.serialize_into(bytes);
self.hskew.serialize_into(bytes);
self.vdisplay.serialize_into(bytes);
self.vsyncstart.serialize_into(bytes);
self.vsyncend.serialize_into(bytes);
self.vtotal.serialize_into(bytes);
bytes.extend_from_slice(&[0; 2]);
u32::from(self.flags).serialize_into(bytes);
bytes.extend_from_slice(&[0; 12]);
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
privsize.serialize_into(bytes);
bytes.extend_from_slice(&self.private);
}
}
impl GetModeLineReply {
pub fn privsize(&self) -> u32 {
self.private.len()
.try_into().unwrap()
}
}
pub const MOD_MODE_LINE_REQUEST: u8 = 2;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ModModeLineRequest<'input> {
pub screen: u32,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub private: Cow<'input, [u8]>,
}
impl_debug_if_no_extra_traits!(ModModeLineRequest<'_>, "ModModeLineRequest");
impl<'input> ModModeLineRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 3]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
let privsize_bytes = privsize.serialize();
let mut request0 = vec![
major_opcode,
MOD_MODE_LINE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
screen_bytes[2],
screen_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
];
let length_so_far = length_so_far + request0.len();
let length_so_far = length_so_far + self.private.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), self.private, padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != MOD_MODE_LINE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u32::try_parse(value)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let _ = remaining;
Ok(ModModeLineRequest {
screen,
hdisplay,
hsyncstart,
hsyncend,
htotal,
hskew,
vdisplay,
vsyncstart,
vsyncend,
vtotal,
flags,
private: Cow::Borrowed(private),
})
}
pub fn into_owned(self) -> ModModeLineRequest<'static> {
ModModeLineRequest {
screen: self.screen,
hdisplay: self.hdisplay,
hsyncstart: self.hsyncstart,
hsyncend: self.hsyncend,
htotal: self.htotal,
hskew: self.hskew,
vdisplay: self.vdisplay,
vsyncstart: self.vsyncstart,
vsyncend: self.vsyncend,
vtotal: self.vtotal,
flags: self.flags,
private: Cow::Owned(self.private.into_owned()),
}
}
}
impl<'input> Request for ModModeLineRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::VoidRequest for ModModeLineRequest<'input> {
}
pub const SWITCH_MODE_REQUEST: u8 = 3;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SwitchModeRequest {
pub screen: u16,
pub zoom: u16,
}
impl_debug_if_no_extra_traits!(SwitchModeRequest, "SwitchModeRequest");
impl SwitchModeRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let zoom_bytes = self.zoom.serialize();
let mut request0 = vec![
major_opcode,
SWITCH_MODE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
zoom_bytes[0],
zoom_bytes[1],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SWITCH_MODE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let (zoom, remaining) = u16::try_parse(remaining)?;
let _ = remaining;
Ok(SwitchModeRequest {
screen,
zoom,
})
}
}
impl Request for SwitchModeRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::VoidRequest for SwitchModeRequest {
}
pub const GET_MONITOR_REQUEST: u8 = 4;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetMonitorRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetMonitorRequest, "GetMonitorRequest");
impl GetMonitorRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_MONITOR_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_MONITOR_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetMonitorRequest {
screen,
})
}
}
impl Request for GetMonitorRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetMonitorRequest {
type Reply = GetMonitorReply;
}
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetMonitorReply {
pub sequence: u16,
pub length: u32,
pub hsync: Vec<Syncrange>,
pub vsync: Vec<Syncrange>,
pub vendor: Vec<u8>,
pub alignment_pad: Vec<u8>,
pub model: Vec<u8>,
}
impl_debug_if_no_extra_traits!(GetMonitorReply, "GetMonitorReply");
impl TryParse for GetMonitorReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (vendor_length, remaining) = u8::try_parse(remaining)?;
let (model_length, remaining) = u8::try_parse(remaining)?;
let (num_hsync, remaining) = u8::try_parse(remaining)?;
let (num_vsync, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(20..).ok_or(ParseError::InsufficientData)?;
let (hsync, remaining) = crate::x11_utils::parse_list::<Syncrange>(remaining, num_hsync.try_to_usize()?)?;
let (vsync, remaining) = crate::x11_utils::parse_list::<Syncrange>(remaining, num_vsync.try_to_usize()?)?;
let (vendor, remaining) = crate::x11_utils::parse_u8_list(remaining, vendor_length.try_to_usize()?)?;
let vendor = vendor.to_vec();
let (alignment_pad, remaining) = crate::x11_utils::parse_u8_list(remaining, (u32::from(vendor_length).checked_add(3u32).ok_or(ParseError::InvalidExpression)? & (!3u32)).checked_sub(u32::from(vendor_length)).ok_or(ParseError::InvalidExpression)?.try_to_usize()?)?;
let alignment_pad = alignment_pad.to_vec();
let (model, remaining) = crate::x11_utils::parse_u8_list(remaining, model_length.try_to_usize()?)?;
let model = model.to_vec();
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetMonitorReply { sequence, length, hsync, vsync, vendor, alignment_pad, model };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetMonitorReply {
type Bytes = Vec<u8>;
fn serialize(&self) -> Vec<u8> {
let mut result = Vec::new();
self.serialize_into(&mut result);
result
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
let vendor_length = u8::try_from(self.vendor.len()).expect("`vendor` has too many elements");
vendor_length.serialize_into(bytes);
let model_length = u8::try_from(self.model.len()).expect("`model` has too many elements");
model_length.serialize_into(bytes);
let num_hsync = u8::try_from(self.hsync.len()).expect("`hsync` has too many elements");
num_hsync.serialize_into(bytes);
let num_vsync = u8::try_from(self.vsync.len()).expect("`vsync` has too many elements");
num_vsync.serialize_into(bytes);
bytes.extend_from_slice(&[0; 20]);
self.hsync.serialize_into(bytes);
self.vsync.serialize_into(bytes);
bytes.extend_from_slice(&self.vendor);
assert_eq!(self.alignment_pad.len(), usize::try_from((u32::from(vendor_length).checked_add(3u32).unwrap() & (!3u32)).checked_sub(u32::from(vendor_length)).unwrap()).unwrap(), "`alignment_pad` has an incorrect length");
bytes.extend_from_slice(&self.alignment_pad);
bytes.extend_from_slice(&self.model);
}
}
impl GetMonitorReply {
pub fn vendor_length(&self) -> u8 {
self.vendor.len()
.try_into().unwrap()
}
pub fn model_length(&self) -> u8 {
self.model.len()
.try_into().unwrap()
}
pub fn num_hsync(&self) -> u8 {
self.hsync.len()
.try_into().unwrap()
}
pub fn num_vsync(&self) -> u8 {
self.vsync.len()
.try_into().unwrap()
}
}
pub const LOCK_MODE_SWITCH_REQUEST: u8 = 5;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct LockModeSwitchRequest {
pub screen: u16,
pub lock: u16,
}
impl_debug_if_no_extra_traits!(LockModeSwitchRequest, "LockModeSwitchRequest");
impl LockModeSwitchRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let lock_bytes = self.lock.serialize();
let mut request0 = vec![
major_opcode,
LOCK_MODE_SWITCH_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
lock_bytes[0],
lock_bytes[1],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != LOCK_MODE_SWITCH_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let (lock, remaining) = u16::try_parse(remaining)?;
let _ = remaining;
Ok(LockModeSwitchRequest {
screen,
lock,
})
}
}
impl Request for LockModeSwitchRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::VoidRequest for LockModeSwitchRequest {
}
pub const GET_ALL_MODE_LINES_REQUEST: u8 = 6;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetAllModeLinesRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetAllModeLinesRequest, "GetAllModeLinesRequest");
impl GetAllModeLinesRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_ALL_MODE_LINES_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_ALL_MODE_LINES_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetAllModeLinesRequest {
screen,
})
}
}
impl Request for GetAllModeLinesRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetAllModeLinesRequest {
type Reply = GetAllModeLinesReply;
}
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetAllModeLinesReply {
pub sequence: u16,
pub length: u32,
pub modeinfo: Vec<ModeInfo>,
}
impl_debug_if_no_extra_traits!(GetAllModeLinesReply, "GetAllModeLinesReply");
impl TryParse for GetAllModeLinesReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (modecount, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(20..).ok_or(ParseError::InsufficientData)?;
let (modeinfo, remaining) = crate::x11_utils::parse_list::<ModeInfo>(remaining, modecount.try_to_usize()?)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetAllModeLinesReply { sequence, length, modeinfo };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetAllModeLinesReply {
type Bytes = Vec<u8>;
fn serialize(&self) -> Vec<u8> {
let mut result = Vec::new();
self.serialize_into(&mut result);
result
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
let modecount = u32::try_from(self.modeinfo.len()).expect("`modeinfo` has too many elements");
modecount.serialize_into(bytes);
bytes.extend_from_slice(&[0; 20]);
self.modeinfo.serialize_into(bytes);
}
}
impl GetAllModeLinesReply {
pub fn modecount(&self) -> u32 {
self.modeinfo.len()
.try_into().unwrap()
}
}
pub const ADD_MODE_LINE_REQUEST: u8 = 7;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct AddModeLineRequest<'input> {
pub screen: u32,
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub after_dotclock: Dotclock,
pub after_hdisplay: u16,
pub after_hsyncstart: u16,
pub after_hsyncend: u16,
pub after_htotal: u16,
pub after_hskew: u16,
pub after_vdisplay: u16,
pub after_vsyncstart: u16,
pub after_vsyncend: u16,
pub after_vtotal: u16,
pub after_flags: ModeFlag,
pub private: Cow<'input, [u8]>,
}
impl_debug_if_no_extra_traits!(AddModeLineRequest<'_>, "AddModeLineRequest");
impl<'input> AddModeLineRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 3]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let dotclock_bytes = self.dotclock.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
let privsize_bytes = privsize.serialize();
let after_dotclock_bytes = self.after_dotclock.serialize();
let after_hdisplay_bytes = self.after_hdisplay.serialize();
let after_hsyncstart_bytes = self.after_hsyncstart.serialize();
let after_hsyncend_bytes = self.after_hsyncend.serialize();
let after_htotal_bytes = self.after_htotal.serialize();
let after_hskew_bytes = self.after_hskew.serialize();
let after_vdisplay_bytes = self.after_vdisplay.serialize();
let after_vsyncstart_bytes = self.after_vsyncstart.serialize();
let after_vsyncend_bytes = self.after_vsyncend.serialize();
let after_vtotal_bytes = self.after_vtotal.serialize();
let after_flags_bytes = u32::from(self.after_flags).serialize();
let mut request0 = vec![
major_opcode,
ADD_MODE_LINE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
screen_bytes[2],
screen_bytes[3],
dotclock_bytes[0],
dotclock_bytes[1],
dotclock_bytes[2],
dotclock_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
after_dotclock_bytes[0],
after_dotclock_bytes[1],
after_dotclock_bytes[2],
after_dotclock_bytes[3],
after_hdisplay_bytes[0],
after_hdisplay_bytes[1],
after_hsyncstart_bytes[0],
after_hsyncstart_bytes[1],
after_hsyncend_bytes[0],
after_hsyncend_bytes[1],
after_htotal_bytes[0],
after_htotal_bytes[1],
after_hskew_bytes[0],
after_hskew_bytes[1],
after_vdisplay_bytes[0],
after_vdisplay_bytes[1],
after_vsyncstart_bytes[0],
after_vsyncstart_bytes[1],
after_vsyncend_bytes[0],
after_vsyncend_bytes[1],
after_vtotal_bytes[0],
after_vtotal_bytes[1],
0,
0,
after_flags_bytes[0],
after_flags_bytes[1],
after_flags_bytes[2],
after_flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
];
let length_so_far = length_so_far + request0.len();
let length_so_far = length_so_far + self.private.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), self.private, padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != ADD_MODE_LINE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u32::try_parse(value)?;
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (after_dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (after_hdisplay, remaining) = u16::try_parse(remaining)?;
let (after_hsyncstart, remaining) = u16::try_parse(remaining)?;
let (after_hsyncend, remaining) = u16::try_parse(remaining)?;
let (after_htotal, remaining) = u16::try_parse(remaining)?;
let (after_hskew, remaining) = u16::try_parse(remaining)?;
let (after_vdisplay, remaining) = u16::try_parse(remaining)?;
let (after_vsyncstart, remaining) = u16::try_parse(remaining)?;
let (after_vsyncend, remaining) = u16::try_parse(remaining)?;
let (after_vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (after_flags, remaining) = u32::try_parse(remaining)?;
let after_flags = after_flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let _ = remaining;
Ok(AddModeLineRequest {
screen,
dotclock,
hdisplay,
hsyncstart,
hsyncend,
htotal,
hskew,
vdisplay,
vsyncstart,
vsyncend,
vtotal,
flags,
after_dotclock,
after_hdisplay,
after_hsyncstart,
after_hsyncend,
after_htotal,
after_hskew,
after_vdisplay,
after_vsyncstart,
after_vsyncend,
after_vtotal,
after_flags,
private: Cow::Borrowed(private),
})
}
pub fn into_owned(self) -> AddModeLineRequest<'static> {
AddModeLineRequest {
screen: self.screen,
dotclock: self.dotclock,
hdisplay: self.hdisplay,
hsyncstart: self.hsyncstart,
hsyncend: self.hsyncend,
htotal: self.htotal,
hskew: self.hskew,
vdisplay: self.vdisplay,
vsyncstart: self.vsyncstart,
vsyncend: self.vsyncend,
vtotal: self.vtotal,
flags: self.flags,
after_dotclock: self.after_dotclock,
after_hdisplay: self.after_hdisplay,
after_hsyncstart: self.after_hsyncstart,
after_hsyncend: self.after_hsyncend,
after_htotal: self.after_htotal,
after_hskew: self.after_hskew,
after_vdisplay: self.after_vdisplay,
after_vsyncstart: self.after_vsyncstart,
after_vsyncend: self.after_vsyncend,
after_vtotal: self.after_vtotal,
after_flags: self.after_flags,
private: Cow::Owned(self.private.into_owned()),
}
}
}
impl<'input> Request for AddModeLineRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::VoidRequest for AddModeLineRequest<'input> {
}
pub const DELETE_MODE_LINE_REQUEST: u8 = 8;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct DeleteModeLineRequest<'input> {
pub screen: u32,
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub private: Cow<'input, [u8]>,
}
impl_debug_if_no_extra_traits!(DeleteModeLineRequest<'_>, "DeleteModeLineRequest");
impl<'input> DeleteModeLineRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 3]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let dotclock_bytes = self.dotclock.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
let privsize_bytes = privsize.serialize();
let mut request0 = vec![
major_opcode,
DELETE_MODE_LINE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
screen_bytes[2],
screen_bytes[3],
dotclock_bytes[0],
dotclock_bytes[1],
dotclock_bytes[2],
dotclock_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
];
let length_so_far = length_so_far + request0.len();
let length_so_far = length_so_far + self.private.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), self.private, padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != DELETE_MODE_LINE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u32::try_parse(value)?;
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let _ = remaining;
Ok(DeleteModeLineRequest {
screen,
dotclock,
hdisplay,
hsyncstart,
hsyncend,
htotal,
hskew,
vdisplay,
vsyncstart,
vsyncend,
vtotal,
flags,
private: Cow::Borrowed(private),
})
}
pub fn into_owned(self) -> DeleteModeLineRequest<'static> {
DeleteModeLineRequest {
screen: self.screen,
dotclock: self.dotclock,
hdisplay: self.hdisplay,
hsyncstart: self.hsyncstart,
hsyncend: self.hsyncend,
htotal: self.htotal,
hskew: self.hskew,
vdisplay: self.vdisplay,
vsyncstart: self.vsyncstart,
vsyncend: self.vsyncend,
vtotal: self.vtotal,
flags: self.flags,
private: Cow::Owned(self.private.into_owned()),
}
}
}
impl<'input> Request for DeleteModeLineRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::VoidRequest for DeleteModeLineRequest<'input> {
}
pub const VALIDATE_MODE_LINE_REQUEST: u8 = 9;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ValidateModeLineRequest<'input> {
pub screen: u32,
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub private: Cow<'input, [u8]>,
}
impl_debug_if_no_extra_traits!(ValidateModeLineRequest<'_>, "ValidateModeLineRequest");
impl<'input> ValidateModeLineRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 3]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let dotclock_bytes = self.dotclock.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
let privsize_bytes = privsize.serialize();
let mut request0 = vec![
major_opcode,
VALIDATE_MODE_LINE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
screen_bytes[2],
screen_bytes[3],
dotclock_bytes[0],
dotclock_bytes[1],
dotclock_bytes[2],
dotclock_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
];
let length_so_far = length_so_far + request0.len();
let length_so_far = length_so_far + self.private.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), self.private, padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != VALIDATE_MODE_LINE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u32::try_parse(value)?;
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let _ = remaining;
Ok(ValidateModeLineRequest {
screen,
dotclock,
hdisplay,
hsyncstart,
hsyncend,
htotal,
hskew,
vdisplay,
vsyncstart,
vsyncend,
vtotal,
flags,
private: Cow::Borrowed(private),
})
}
pub fn into_owned(self) -> ValidateModeLineRequest<'static> {
ValidateModeLineRequest {
screen: self.screen,
dotclock: self.dotclock,
hdisplay: self.hdisplay,
hsyncstart: self.hsyncstart,
hsyncend: self.hsyncend,
htotal: self.htotal,
hskew: self.hskew,
vdisplay: self.vdisplay,
vsyncstart: self.vsyncstart,
vsyncend: self.vsyncend,
vtotal: self.vtotal,
flags: self.flags,
private: Cow::Owned(self.private.into_owned()),
}
}
}
impl<'input> Request for ValidateModeLineRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::ReplyRequest for ValidateModeLineRequest<'input> {
type Reply = ValidateModeLineReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct ValidateModeLineReply {
pub sequence: u16,
pub length: u32,
pub status: u32,
}
impl_debug_if_no_extra_traits!(ValidateModeLineReply, "ValidateModeLineReply");
impl TryParse for ValidateModeLineReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (status, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(20..).ok_or(ParseError::InsufficientData)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = ValidateModeLineReply { sequence, length, status };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for ValidateModeLineReply {
type Bytes = [u8; 32];
fn serialize(&self) -> [u8; 32] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let status_bytes = self.status.serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
status_bytes[0],
status_bytes[1],
status_bytes[2],
status_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.status.serialize_into(bytes);
bytes.extend_from_slice(&[0; 20]);
}
}
pub const SWITCH_TO_MODE_REQUEST: u8 = 10;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SwitchToModeRequest<'input> {
pub screen: u32,
pub dotclock: Dotclock,
pub hdisplay: u16,
pub hsyncstart: u16,
pub hsyncend: u16,
pub htotal: u16,
pub hskew: u16,
pub vdisplay: u16,
pub vsyncstart: u16,
pub vsyncend: u16,
pub vtotal: u16,
pub flags: ModeFlag,
pub private: Cow<'input, [u8]>,
}
impl_debug_if_no_extra_traits!(SwitchToModeRequest<'_>, "SwitchToModeRequest");
impl<'input> SwitchToModeRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 3]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let dotclock_bytes = self.dotclock.serialize();
let hdisplay_bytes = self.hdisplay.serialize();
let hsyncstart_bytes = self.hsyncstart.serialize();
let hsyncend_bytes = self.hsyncend.serialize();
let htotal_bytes = self.htotal.serialize();
let hskew_bytes = self.hskew.serialize();
let vdisplay_bytes = self.vdisplay.serialize();
let vsyncstart_bytes = self.vsyncstart.serialize();
let vsyncend_bytes = self.vsyncend.serialize();
let vtotal_bytes = self.vtotal.serialize();
let flags_bytes = u32::from(self.flags).serialize();
let privsize = u32::try_from(self.private.len()).expect("`private` has too many elements");
let privsize_bytes = privsize.serialize();
let mut request0 = vec![
major_opcode,
SWITCH_TO_MODE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
screen_bytes[2],
screen_bytes[3],
dotclock_bytes[0],
dotclock_bytes[1],
dotclock_bytes[2],
dotclock_bytes[3],
hdisplay_bytes[0],
hdisplay_bytes[1],
hsyncstart_bytes[0],
hsyncstart_bytes[1],
hsyncend_bytes[0],
hsyncend_bytes[1],
htotal_bytes[0],
htotal_bytes[1],
hskew_bytes[0],
hskew_bytes[1],
vdisplay_bytes[0],
vdisplay_bytes[1],
vsyncstart_bytes[0],
vsyncstart_bytes[1],
vsyncend_bytes[0],
vsyncend_bytes[1],
vtotal_bytes[0],
vtotal_bytes[1],
0,
0,
flags_bytes[0],
flags_bytes[1],
flags_bytes[2],
flags_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
privsize_bytes[0],
privsize_bytes[1],
privsize_bytes[2],
privsize_bytes[3],
];
let length_so_far = length_so_far + request0.len();
let length_so_far = length_so_far + self.private.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), self.private, padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SWITCH_TO_MODE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u32::try_parse(value)?;
let (dotclock, remaining) = Dotclock::try_parse(remaining)?;
let (hdisplay, remaining) = u16::try_parse(remaining)?;
let (hsyncstart, remaining) = u16::try_parse(remaining)?;
let (hsyncend, remaining) = u16::try_parse(remaining)?;
let (htotal, remaining) = u16::try_parse(remaining)?;
let (hskew, remaining) = u16::try_parse(remaining)?;
let (vdisplay, remaining) = u16::try_parse(remaining)?;
let (vsyncstart, remaining) = u16::try_parse(remaining)?;
let (vsyncend, remaining) = u16::try_parse(remaining)?;
let (vtotal, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let flags = flags.into();
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (privsize, remaining) = u32::try_parse(remaining)?;
let (private, remaining) = crate::x11_utils::parse_u8_list(remaining, privsize.try_to_usize()?)?;
let _ = remaining;
Ok(SwitchToModeRequest {
screen,
dotclock,
hdisplay,
hsyncstart,
hsyncend,
htotal,
hskew,
vdisplay,
vsyncstart,
vsyncend,
vtotal,
flags,
private: Cow::Borrowed(private),
})
}
pub fn into_owned(self) -> SwitchToModeRequest<'static> {
SwitchToModeRequest {
screen: self.screen,
dotclock: self.dotclock,
hdisplay: self.hdisplay,
hsyncstart: self.hsyncstart,
hsyncend: self.hsyncend,
htotal: self.htotal,
hskew: self.hskew,
vdisplay: self.vdisplay,
vsyncstart: self.vsyncstart,
vsyncend: self.vsyncend,
vtotal: self.vtotal,
flags: self.flags,
private: Cow::Owned(self.private.into_owned()),
}
}
}
impl<'input> Request for SwitchToModeRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::VoidRequest for SwitchToModeRequest<'input> {
}
pub const GET_VIEW_PORT_REQUEST: u8 = 11;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetViewPortRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetViewPortRequest, "GetViewPortRequest");
impl GetViewPortRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_VIEW_PORT_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_VIEW_PORT_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetViewPortRequest {
screen,
})
}
}
impl Request for GetViewPortRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetViewPortRequest {
type Reply = GetViewPortReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetViewPortReply {
pub sequence: u16,
pub length: u32,
pub x: u32,
pub y: u32,
}
impl_debug_if_no_extra_traits!(GetViewPortReply, "GetViewPortReply");
impl TryParse for GetViewPortReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (x, remaining) = u32::try_parse(remaining)?;
let (y, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(16..).ok_or(ParseError::InsufficientData)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetViewPortReply { sequence, length, x, y };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetViewPortReply {
type Bytes = [u8; 32];
fn serialize(&self) -> [u8; 32] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let x_bytes = self.x.serialize();
let y_bytes = self.y.serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
x_bytes[0],
x_bytes[1],
x_bytes[2],
x_bytes[3],
y_bytes[0],
y_bytes[1],
y_bytes[2],
y_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.x.serialize_into(bytes);
self.y.serialize_into(bytes);
bytes.extend_from_slice(&[0; 16]);
}
}
pub const SET_VIEW_PORT_REQUEST: u8 = 12;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SetViewPortRequest {
pub screen: u16,
pub x: u32,
pub y: u32,
}
impl_debug_if_no_extra_traits!(SetViewPortRequest, "SetViewPortRequest");
impl SetViewPortRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let x_bytes = self.x.serialize();
let y_bytes = self.y.serialize();
let mut request0 = vec![
major_opcode,
SET_VIEW_PORT_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
x_bytes[0],
x_bytes[1],
x_bytes[2],
x_bytes[3],
y_bytes[0],
y_bytes[1],
y_bytes[2],
y_bytes[3],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SET_VIEW_PORT_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (x, remaining) = u32::try_parse(remaining)?;
let (y, remaining) = u32::try_parse(remaining)?;
let _ = remaining;
Ok(SetViewPortRequest {
screen,
x,
y,
})
}
}
impl Request for SetViewPortRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::VoidRequest for SetViewPortRequest {
}
pub const GET_DOT_CLOCKS_REQUEST: u8 = 13;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetDotClocksRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetDotClocksRequest, "GetDotClocksRequest");
impl GetDotClocksRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_DOT_CLOCKS_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_DOT_CLOCKS_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetDotClocksRequest {
screen,
})
}
}
impl Request for GetDotClocksRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetDotClocksRequest {
type Reply = GetDotClocksReply;
}
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetDotClocksReply {
pub sequence: u16,
pub length: u32,
pub flags: ClockFlag,
pub clocks: u32,
pub maxclocks: u32,
pub clock: Vec<u32>,
}
impl_debug_if_no_extra_traits!(GetDotClocksReply, "GetDotClocksReply");
impl TryParse for GetDotClocksReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (flags, remaining) = u32::try_parse(remaining)?;
let (clocks, remaining) = u32::try_parse(remaining)?;
let (maxclocks, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let (clock, remaining) = crate::x11_utils::parse_list::<u32>(remaining, 1u32.checked_sub(u32::from(flags) & 1u32).ok_or(ParseError::InvalidExpression)?.checked_mul(u32::from(clocks)).ok_or(ParseError::InvalidExpression)?.try_to_usize()?)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let flags = flags.into();
let result = GetDotClocksReply { sequence, length, flags, clocks, maxclocks, clock };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetDotClocksReply {
type Bytes = Vec<u8>;
fn serialize(&self) -> Vec<u8> {
let mut result = Vec::new();
self.serialize_into(&mut result);
result
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
u32::from(self.flags).serialize_into(bytes);
self.clocks.serialize_into(bytes);
self.maxclocks.serialize_into(bytes);
bytes.extend_from_slice(&[0; 12]);
assert_eq!(self.clock.len(), usize::try_from(1u32.checked_sub(u32::from(self.flags) & 1u32).unwrap().checked_mul(u32::from(self.clocks)).unwrap()).unwrap(), "`clock` has an incorrect length");
self.clock.serialize_into(bytes);
}
}
pub const SET_CLIENT_VERSION_REQUEST: u8 = 14;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SetClientVersionRequest {
pub major: u16,
pub minor: u16,
}
impl_debug_if_no_extra_traits!(SetClientVersionRequest, "SetClientVersionRequest");
impl SetClientVersionRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let major_bytes = self.major.serialize();
let minor_bytes = self.minor.serialize();
let mut request0 = vec![
major_opcode,
SET_CLIENT_VERSION_REQUEST,
0,
0,
major_bytes[0],
major_bytes[1],
minor_bytes[0],
minor_bytes[1],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SET_CLIENT_VERSION_REQUEST {
return Err(ParseError::InvalidValue);
}
let (major, remaining) = u16::try_parse(value)?;
let (minor, remaining) = u16::try_parse(remaining)?;
let _ = remaining;
Ok(SetClientVersionRequest {
major,
minor,
})
}
}
impl Request for SetClientVersionRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::VoidRequest for SetClientVersionRequest {
}
pub const SET_GAMMA_REQUEST: u8 = 15;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SetGammaRequest {
pub screen: u16,
pub red: u32,
pub green: u32,
pub blue: u32,
}
impl_debug_if_no_extra_traits!(SetGammaRequest, "SetGammaRequest");
impl SetGammaRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let red_bytes = self.red.serialize();
let green_bytes = self.green.serialize();
let blue_bytes = self.blue.serialize();
let mut request0 = vec![
major_opcode,
SET_GAMMA_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
red_bytes[0],
red_bytes[1],
red_bytes[2],
red_bytes[3],
green_bytes[0],
green_bytes[1],
green_bytes[2],
green_bytes[3],
blue_bytes[0],
blue_bytes[1],
blue_bytes[2],
blue_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SET_GAMMA_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let (red, remaining) = u32::try_parse(remaining)?;
let (green, remaining) = u32::try_parse(remaining)?;
let (blue, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(SetGammaRequest {
screen,
red,
green,
blue,
})
}
}
impl Request for SetGammaRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::VoidRequest for SetGammaRequest {
}
pub const GET_GAMMA_REQUEST: u8 = 16;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetGammaRequest, "GetGammaRequest");
impl GetGammaRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_GAMMA_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_GAMMA_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(26..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetGammaRequest {
screen,
})
}
}
impl Request for GetGammaRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetGammaRequest {
type Reply = GetGammaReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaReply {
pub sequence: u16,
pub length: u32,
pub red: u32,
pub green: u32,
pub blue: u32,
}
impl_debug_if_no_extra_traits!(GetGammaReply, "GetGammaReply");
impl TryParse for GetGammaReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (red, remaining) = u32::try_parse(remaining)?;
let (green, remaining) = u32::try_parse(remaining)?;
let (blue, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(12..).ok_or(ParseError::InsufficientData)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetGammaReply { sequence, length, red, green, blue };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetGammaReply {
type Bytes = [u8; 32];
fn serialize(&self) -> [u8; 32] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let red_bytes = self.red.serialize();
let green_bytes = self.green.serialize();
let blue_bytes = self.blue.serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
red_bytes[0],
red_bytes[1],
red_bytes[2],
red_bytes[3],
green_bytes[0],
green_bytes[1],
green_bytes[2],
green_bytes[3],
blue_bytes[0],
blue_bytes[1],
blue_bytes[2],
blue_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.red.serialize_into(bytes);
self.green.serialize_into(bytes);
self.blue.serialize_into(bytes);
bytes.extend_from_slice(&[0; 12]);
}
}
pub const GET_GAMMA_RAMP_REQUEST: u8 = 17;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaRampRequest {
pub screen: u16,
pub size: u16,
}
impl_debug_if_no_extra_traits!(GetGammaRampRequest, "GetGammaRampRequest");
impl GetGammaRampRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let size_bytes = self.size.serialize();
let mut request0 = vec![
major_opcode,
GET_GAMMA_RAMP_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
size_bytes[0],
size_bytes[1],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_GAMMA_RAMP_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let (size, remaining) = u16::try_parse(remaining)?;
let _ = remaining;
Ok(GetGammaRampRequest {
screen,
size,
})
}
}
impl Request for GetGammaRampRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetGammaRampRequest {
type Reply = GetGammaRampReply;
}
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaRampReply {
pub sequence: u16,
pub length: u32,
pub size: u16,
pub red: Vec<u16>,
pub green: Vec<u16>,
pub blue: Vec<u16>,
}
impl_debug_if_no_extra_traits!(GetGammaRampReply, "GetGammaRampReply");
impl TryParse for GetGammaRampReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (size, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(22..).ok_or(ParseError::InsufficientData)?;
let (red, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
let (green, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
let (blue, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetGammaRampReply { sequence, length, size, red, green, blue };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetGammaRampReply {
type Bytes = Vec<u8>;
fn serialize(&self) -> Vec<u8> {
let mut result = Vec::new();
self.serialize_into(&mut result);
result
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.size.serialize_into(bytes);
bytes.extend_from_slice(&[0; 22]);
assert_eq!(self.red.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`red` has an incorrect length");
self.red.serialize_into(bytes);
assert_eq!(self.green.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`green` has an incorrect length");
self.green.serialize_into(bytes);
assert_eq!(self.blue.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`blue` has an incorrect length");
self.blue.serialize_into(bytes);
}
}
pub const SET_GAMMA_RAMP_REQUEST: u8 = 18;
#[derive(Clone, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct SetGammaRampRequest<'input> {
pub screen: u16,
pub size: u16,
pub red: Cow<'input, [u16]>,
pub green: Cow<'input, [u16]>,
pub blue: Cow<'input, [u16]>,
}
impl_debug_if_no_extra_traits!(SetGammaRampRequest<'_>, "SetGammaRampRequest");
impl<'input> SetGammaRampRequest<'input> {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'input, [u8]>; 5]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let size_bytes = self.size.serialize();
let mut request0 = vec![
major_opcode,
SET_GAMMA_RAMP_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
size_bytes[0],
size_bytes[1],
];
let length_so_far = length_so_far + request0.len();
assert_eq!(self.red.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`red` has an incorrect length");
let red_bytes = self.red.serialize();
let length_so_far = length_so_far + red_bytes.len();
assert_eq!(self.green.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`green` has an incorrect length");
let green_bytes = self.green.serialize();
let length_so_far = length_so_far + green_bytes.len();
assert_eq!(self.blue.len(), usize::try_from(u32::from(self.size).checked_add(1u32).unwrap() & (!1u32)).unwrap(), "`blue` has an incorrect length");
let blue_bytes = self.blue.serialize();
let length_so_far = length_so_far + blue_bytes.len();
let padding0 = &[0; 3][..(4 - (length_so_far % 4)) % 4];
let length_so_far = length_so_far + padding0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into(), red_bytes.into(), green_bytes.into(), blue_bytes.into(), padding0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &'input [u8]) -> Result<Self, ParseError> {
if header.minor_opcode != SET_GAMMA_RAMP_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let (size, remaining) = u16::try_parse(remaining)?;
let (red, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
let (green, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
let (blue, remaining) = crate::x11_utils::parse_list::<u16>(remaining, (u32::from(size).checked_add(1u32).ok_or(ParseError::InvalidExpression)? & (!1u32)).try_to_usize()?)?;
let _ = remaining;
Ok(SetGammaRampRequest {
screen,
size,
red: Cow::Owned(red),
green: Cow::Owned(green),
blue: Cow::Owned(blue),
})
}
pub fn into_owned(self) -> SetGammaRampRequest<'static> {
SetGammaRampRequest {
screen: self.screen,
size: self.size,
red: Cow::Owned(self.red.into_owned()),
green: Cow::Owned(self.green.into_owned()),
blue: Cow::Owned(self.blue.into_owned()),
}
}
}
impl<'input> Request for SetGammaRampRequest<'input> {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl<'input> crate::x11_utils::VoidRequest for SetGammaRampRequest<'input> {
}
pub const GET_GAMMA_RAMP_SIZE_REQUEST: u8 = 19;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaRampSizeRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetGammaRampSizeRequest, "GetGammaRampSizeRequest");
impl GetGammaRampSizeRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_GAMMA_RAMP_SIZE_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_GAMMA_RAMP_SIZE_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetGammaRampSizeRequest {
screen,
})
}
}
impl Request for GetGammaRampSizeRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetGammaRampSizeRequest {
type Reply = GetGammaRampSizeReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetGammaRampSizeReply {
pub sequence: u16,
pub length: u32,
pub size: u16,
}
impl_debug_if_no_extra_traits!(GetGammaRampSizeReply, "GetGammaRampSizeReply");
impl TryParse for GetGammaRampSizeReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (size, remaining) = u16::try_parse(remaining)?;
let remaining = remaining.get(22..).ok_or(ParseError::InsufficientData)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let result = GetGammaRampSizeReply { sequence, length, size };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetGammaRampSizeReply {
type Bytes = [u8; 32];
fn serialize(&self) -> [u8; 32] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let size_bytes = self.size.serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
size_bytes[0],
size_bytes[1],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
self.size.serialize_into(bytes);
bytes.extend_from_slice(&[0; 22]);
}
}
pub const GET_PERMISSIONS_REQUEST: u8 = 20;
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetPermissionsRequest {
pub screen: u16,
}
impl_debug_if_no_extra_traits!(GetPermissionsRequest, "GetPermissionsRequest");
impl GetPermissionsRequest {
pub fn serialize(self, major_opcode: u8) -> BufWithFds<[Cow<'static, [u8]>; 1]> {
let length_so_far = 0;
let screen_bytes = self.screen.serialize();
let mut request0 = vec![
major_opcode,
GET_PERMISSIONS_REQUEST,
0,
0,
screen_bytes[0],
screen_bytes[1],
0,
0,
];
let length_so_far = length_so_far + request0.len();
assert_eq!(length_so_far % 4, 0);
let length = u16::try_from(length_so_far / 4).unwrap_or(0);
request0[2..4].copy_from_slice(&length.to_ne_bytes());
([request0.into()], vec![])
}
#[cfg(feature = "request-parsing")]
pub fn try_parse_request(header: RequestHeader, value: &[u8]) -> Result<Self, ParseError> {
if header.minor_opcode != GET_PERMISSIONS_REQUEST {
return Err(ParseError::InvalidValue);
}
let (screen, remaining) = u16::try_parse(value)?;
let remaining = remaining.get(2..).ok_or(ParseError::InsufficientData)?;
let _ = remaining;
Ok(GetPermissionsRequest {
screen,
})
}
}
impl Request for GetPermissionsRequest {
const EXTENSION_NAME: Option<&'static str> = Some(X11_EXTENSION_NAME);
fn serialize(self, major_opcode: u8) -> BufWithFds<Vec<u8>> {
let (bufs, fds) = self.serialize(major_opcode);
let buf = bufs.iter().flat_map(|buf| buf.iter().copied()).collect();
(buf, fds)
}
}
impl crate::x11_utils::ReplyRequest for GetPermissionsRequest {
type Reply = GetPermissionsReply;
}
#[derive(Clone, Copy, Default)]
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct GetPermissionsReply {
pub sequence: u16,
pub length: u32,
pub permissions: Permission,
}
impl_debug_if_no_extra_traits!(GetPermissionsReply, "GetPermissionsReply");
impl TryParse for GetPermissionsReply {
fn try_parse(initial_value: &[u8]) -> Result<(Self, &[u8]), ParseError> {
let remaining = initial_value;
let (response_type, remaining) = u8::try_parse(remaining)?;
let remaining = remaining.get(1..).ok_or(ParseError::InsufficientData)?;
let (sequence, remaining) = u16::try_parse(remaining)?;
let (length, remaining) = u32::try_parse(remaining)?;
let (permissions, remaining) = u32::try_parse(remaining)?;
let remaining = remaining.get(20..).ok_or(ParseError::InsufficientData)?;
if response_type != 1 {
return Err(ParseError::InvalidValue);
}
let permissions = permissions.into();
let result = GetPermissionsReply { sequence, length, permissions };
let _ = remaining;
let remaining = initial_value.get(32 + length as usize * 4..)
.ok_or(ParseError::InsufficientData)?;
Ok((result, remaining))
}
}
impl Serialize for GetPermissionsReply {
type Bytes = [u8; 32];
fn serialize(&self) -> [u8; 32] {
let response_type_bytes = &[1];
let sequence_bytes = self.sequence.serialize();
let length_bytes = self.length.serialize();
let permissions_bytes = u32::from(self.permissions).serialize();
[
response_type_bytes[0],
0,
sequence_bytes[0],
sequence_bytes[1],
length_bytes[0],
length_bytes[1],
length_bytes[2],
length_bytes[3],
permissions_bytes[0],
permissions_bytes[1],
permissions_bytes[2],
permissions_bytes[3],
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
]
}
fn serialize_into(&self, bytes: &mut Vec<u8>) {
bytes.reserve(32);
let response_type_bytes = &[1];
bytes.push(response_type_bytes[0]);
bytes.extend_from_slice(&[0; 1]);
self.sequence.serialize_into(bytes);
self.length.serialize_into(bytes);
u32::from(self.permissions).serialize_into(bytes);
bytes.extend_from_slice(&[0; 20]);
}
}
pub const BAD_CLOCK_ERROR: u8 = 0;
pub const BAD_H_TIMINGS_ERROR: u8 = 1;
pub const BAD_V_TIMINGS_ERROR: u8 = 2;
pub const MODE_UNSUITABLE_ERROR: u8 = 3;
pub const EXTENSION_DISABLED_ERROR: u8 = 4;
pub const CLIENT_NOT_LOCAL_ERROR: u8 = 5;
pub const ZOOM_LOCKED_ERROR: u8 = 6;