[INFO] fetching crate zwp-input-method 0.3.1... [INFO] checking zwp-input-method-0.3.1 against master#ab869e094a907cc5d19b4080f22eccaf347f1f95 for pr-129604 [INFO] extracting crate zwp-input-method 0.3.1 into /workspace/builds/worker-1-tc1/source [INFO] validating manifest of crates.io crate zwp-input-method 0.3.1 on toolchain ab869e094a907cc5d19b4080f22eccaf347f1f95 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking crates.io crate zwp-input-method 0.3.1 [INFO] finished tweaking crates.io crate zwp-input-method 0.3.1 [INFO] tweaked toml for crates.io crate zwp-input-method 0.3.1 written to /workspace/builds/worker-1-tc1/source/Cargo.toml [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 20 packages to latest compatible versions [INFO] [stderr] Adding bitflags v1.3.2 (latest: v2.6.0) [INFO] [stderr] Adding memoffset v0.6.5 (latest: v0.9.1) [INFO] [stderr] Adding nix v0.24.3 (latest: v0.29.0) [INFO] [stderr] Adding wayland-client v0.29.5 (latest: v0.31.5) [INFO] [stderr] Adding wayland-protocols v0.29.5 (latest: v0.32.3) [INFO] [stderr] Adding wayland-scanner v0.29.5 (latest: v0.31.4) [INFO] [stderr] Adding wayland-sys v0.29.5 (latest: v0.31.4) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 0bb57e6e125ca7bdcff054f510cb55f00bf46f9ff1de68c85ef14dc424354800 [INFO] running `Command { std: "docker" "start" "-a" "0bb57e6e125ca7bdcff054f510cb55f00bf46f9ff1de68c85ef14dc424354800", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "0bb57e6e125ca7bdcff054f510cb55f00bf46f9ff1de68c85ef14dc424354800", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0bb57e6e125ca7bdcff054f510cb55f00bf46f9ff1de68c85ef14dc424354800", kill_on_drop: false }` [INFO] [stdout] 0bb57e6e125ca7bdcff054f510cb55f00bf46f9ff1de68c85ef14dc424354800 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 29eb953adf3c860ed9363de1b38acdb2185078cea189f32a842e43fd4916af63 [INFO] running `Command { std: "docker" "start" "-a" "29eb953adf3c860ed9363de1b38acdb2185078cea189f32a842e43fd4916af63", kill_on_drop: false }` [INFO] [stderr] Compiling xml-rs v0.8.21 [INFO] [stderr] Compiling libc v0.2.158 [INFO] [stderr] Compiling memoffset v0.6.5 [INFO] [stderr] Compiling wayland-sys v0.29.5 [INFO] [stderr] Checking downcast-rs v1.2.1 [INFO] [stderr] Compiling wayland-scanner v0.29.5 [INFO] [stderr] Compiling wayland-client v0.29.5 [INFO] [stderr] Compiling wayland-protocols v0.29.5 [INFO] [stderr] Compiling zwp-input-method v0.3.1 (/opt/rustwide/workdir) [INFO] [stderr] Checking nix v0.24.3 [INFO] [stderr] Checking wayland-commons v0.29.5 [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31373 [INFO] [stdout] | [INFO] [stdout] 1 | ... [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] = note: `#[warn(static_mut_refs)]` on by default [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { addr_of!(super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface) as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31373 [INFO] [stdout] | [INFO] [stdout] 1 | ... [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] = note: `#[warn(static_mut_refs)]` on by default [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { addr_of!(super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface) as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31488 [INFO] [stdout] | [INFO] [stdout] 1 | ... wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { addr_of!(super :: wl_surface :: wl_surface_interface) as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31488 [INFO] [stdout] | [INFO] [stdout] 1 | ... wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { addr_of!(super :: wl_surface :: wl_surface_interface) as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31666 [INFO] [stdout] | [INFO] [stdout] 1 | ...e { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { addr_of!(super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface) as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:31666 [INFO] [stdout] | [INFO] [stdout] 1 | ...e { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { addr_of!(super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface) as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32076 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32076 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32260 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32448 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32260 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32618 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32448 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32806 [INFO] [stdout] | [INFO] [stdout] 1 | ..., types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboa... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { addr_of!(zwp_input_method_v2_requests_get_input_popup_surface_types) as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32618 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33031 [INFO] [stdout] | [INFO] [stdout] 1 | ...char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { addr_of!(zwp_input_method_v2_requests_grab_keyboard_types) as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:32806 [INFO] [stdout] | [INFO] [stdout] 1 | ..., types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboa... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { addr_of!(zwp_input_method_v2_requests_get_input_popup_surface_types) as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33239 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33031 [INFO] [stdout] | [INFO] [stdout] 1 | ...char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { addr_of!(zwp_input_method_v2_requests_grab_keyboard_types) as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33555 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * co... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33239 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33728 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 a... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33555 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * co... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33910 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33728 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 a... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:33910 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34091 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34091 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * ... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34268 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34268 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34435 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * c... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34435 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * c... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34609 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for in... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34609 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for in... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34905 [INFO] [stdout] | [INFO] [stdout] 1 | ...t_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_meth... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { addr_of!(zwp_input_method_v2_requests) as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34905 [INFO] [stdout] | [INFO] [stdout] 1 | ...t_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_meth... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { addr_of!(zwp_input_method_v2_requests) as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34989 [INFO] [stdout] | [INFO] [stdout] 1 | ...vent_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { addr_of!(zwp_input_method_v2_events) as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:34989 [INFO] [stdout] | [INFO] [stdout] 1 | ...vent_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { addr_of!(zwp_input_method_v2_events) as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:41504 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:41504 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:41843 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for in... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:41843 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for in... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:42153 [INFO] [stdout] | [INFO] [stdout] 1 | ...ount : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { addr_of!(zwp_input_popup_surface_v2_requests) as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:42153 [INFO] [stdout] | [INFO] [stdout] 1 | ...ount : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { addr_of!(zwp_input_popup_surface_v2_requests) as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:42244 [INFO] [stdout] | [INFO] [stdout] 1 | ...t_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_me... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { addr_of!(zwp_input_popup_surface_v2_events) as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:42244 [INFO] [stdout] | [INFO] [stdout] 1 | ...t_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_me... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { addr_of!(zwp_input_popup_surface_v2_events) as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:52954 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:52954 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this i... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:53285 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_c... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:53455 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:53285 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_c... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:53632 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * c... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [INFO] [stdout] 1 | use std :: os :: raw :: { c_char , c_void } ; const NULLPTR : * const c_void = 0 as * const c_void ; static mut types_null : [* const sys :: common :: wl_interface ; 5] = [NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface , NULLPTR as * const sys :: common :: wl_interface ,] ; # [doc = "input method\n\nAn input method object allows for clients to compose text.\n\nThe objects connects the client to a text input in an application, and\nlets the client to serve as an input method for a seat.\n\nThe zwp_input_method_v2 object can occupy two distinct states: active and\ninactive. In the active state, the object is associated to and\ncommunicates with a text input. In the inactive state, there is no\nassociated text input, and the only communication is with the compositor.\nInitially, the input method is in the inactive state.\n\nRequests issued in the inactive state must be accepted by the compositor.\nBecause of the serial mechanism, and the state reset on activate event,\nthey will not have any effect on the state of the next text input.\n\nThere must be no more than one input method object per seat."] pub mod zwp_input_method_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [repr (u32)] # [derive (Copy , Clone , Debug , PartialEq)] # [non_exhaustive] pub enum Error { # [doc = "wl_surface has another role"] Role = 0 , } impl Error { pub fn from_raw (n : u32) -> Option < Error > { match n { 0 => Some (Error :: Role) , _ => Option :: None } } pub fn to_raw (& self) -> u32 { * self as u32 } } # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] CommitString { text : String , } , # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] SetPreeditString { text : String , cursor_begin : i32 , cursor_end : i32 , } , # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] DeleteSurroundingText { before_length : u32 , after_length : u32 , } , # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] Commit { serial : u32 , } , # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] GetInputPopupSurface { surface : super :: wl_surface :: WlSurface , } , # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] GrabKeyboard { } , # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "commit_string" , since : 1 , signature : & [super :: ArgumentType :: Str ,] , destructor : false , } , super :: MessageDesc { name : "set_preedit_string" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } , super :: MessageDesc { name : "delete_surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "commit" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "get_input_popup_surface" , since : 1 , signature : & [super :: ArgumentType :: NewId , super :: ArgumentType :: Object ,] , destructor : false , } , super :: MessageDesc { name : "grab_keyboard" , since : 1 , signature : & [super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: CommitString { .. } => 0 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 2 , Request :: Commit { .. } => 3 , Request :: GetInputPopupSurface { .. } => 4 , Request :: GrabKeyboard { .. } => 5 , Request :: Destroy => 6 , } } fn since (& self) -> u32 { match * self { Request :: CommitString { .. } => 1 , Request :: SetPreeditString { .. } => 1 , Request :: DeleteSurroundingText { .. } => 1 , Request :: Commit { .. } => 1 , Request :: GetInputPopupSurface { .. } => 1 , Request :: GrabKeyboard { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 4 => Some (Object :: from_interface :: < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > (version , meta . child () ,)) , 5 => Some (Object :: from_interface :: < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: CommitString { text } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) ,] , } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [Argument :: Str (Box :: new (unsafe { :: std :: ffi :: CString :: from_vec_unchecked (text . into ()) })) , Argument :: Int (cursor_begin) , Argument :: Int (cursor_end) ,] , } , Request :: DeleteSurroundingText { before_length , after_length } => Message { sender_id : sender_id , opcode : 2 , args : smallvec ! [Argument :: Uint (before_length) , Argument :: Uint (after_length) ,] , } , Request :: Commit { serial } => Message { sender_id : sender_id , opcode : 3 , args : smallvec ! [Argument :: Uint (serial) ,] , } , Request :: GetInputPopupSurface { surface } => Message { sender_id : sender_id , opcode : 4 , args : smallvec ! [Argument :: NewId (0) , Argument :: Object (surface . as_ref () . id ()) ,] , } , Request :: GrabKeyboard { } => Message { sender_id : sender_id , opcode : 5 , args : smallvec ! [Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 6 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: CommitString { text } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; f (0 , & mut _args_array) } , Request :: SetPreeditString { text , cursor_begin , cursor_end } => { let mut _args_array : [wl_argument ; 3] = unsafe { :: std :: mem :: zeroed () } ; let _arg_0 = :: std :: ffi :: CString :: new (text) . unwrap () ; _args_array [0] . s = _arg_0 . as_ptr () ; _args_array [1] . i = cursor_begin ; _args_array [2] . i = cursor_end ; f (1 , & mut _args_array) } , Request :: DeleteSurroundingText { before_length , after_length } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = before_length ; _args_array [1] . u = after_length ; f (2 , & mut _args_array) } , Request :: Commit { serial } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . u = serial ; f (3 , & mut _args_array) } , Request :: GetInputPopupSurface { surface } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; _args_array [1] . o = surface . as_ref () . c_ptr () as * mut _ ; f (4 , & mut _args_array) } , Request :: GrabKeyboard { } => { let mut _args_array : [wl_argument ; 1] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = :: std :: ptr :: null_mut () as * mut _ ; f (5 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (6 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "input method has been requested\n\nNotification that a text input focused on this seat requested the input\nmethod to be activated.\n\nThis event serves the purpose of providing the compositor with an\nactive input method.\n\nThis event resets all state associated with previous enable, disable,\nsurrounding_text, text_change_cause, and content_type events, as well\nas the state associated with set_preedit_string, commit_string, and\ndelete_surrounding_text requests. In addition, it marks the\nzwp_input_method_v2 object as active, and makes any existing\nzwp_input_popup_surface_v2 objects visible.\n\nThe surrounding_text, and content_type events must follow before the\nnext done event if the text input supports the respective\nfunctionality.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Activate , # [doc = "deactivate event\n\nNotification that no focused text input currently needs an active\ninput method on this seat.\n\nThis event marks the zwp_input_method_v2 object as inactive. The\ncompositor must make all existing zwp_input_popup_surface_v2 objects\ninvisible until the next activate event.\n\nState set with this event is double-buffered. It will get applied on\nthe next zwp_input_method_v2.done event, and stay valid until changed."] Deactivate , # [doc = "surrounding text event\n\nUpdates the surrounding plain text around the cursor, excluding the\npreedit text.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event.\n\nThe argument text is a buffer containing the preedit string, and must\ninclude the cursor position, and the complete selection. It should\ncontain additional characters before and after these. There is a\nmaximum length of wayland messages, so text can not be longer than 4000\nbytes.\n\ncursor is the byte offset of the cursor within the text buffer.\n\nanchor is the byte offset of the selection anchor within the text\nbuffer. If there is no selected text, anchor must be the same as\ncursor.\n\nIf this event does not arrive before the first done event, the input\nmethod may assume that the text input does not support this\nfunctionality and ignore following surrounding_text events.\n\nValues set with this event are double-buffered. They will get applied\nand set to initial values on the next zwp_input_method_v2.done\nevent.\n\nThe initial state for affected fields is empty, meaning that the text\ninput does not support sending surrounding text. If the empty values\nget applied, subsequent attempts to change them may have no effect."] SurroundingText { text : String , cursor : u32 , anchor : u32 , } , # [doc = "indicates the cause of surrounding text change\n\nTells the input method why the text surrounding the cursor changed.\n\nWhenever the client detects an external change in text, cursor, or\nanchor position, it must issue this request to the compositor. This\nrequest is intended to give the input method a chance to update the\npreedit text in an appropriate way, e.g. by removing it when the user\nstarts typing with a keyboard.\n\ncause describes the source of the change.\n\nThe value set with this event is double-buffered. It will get applied\nand set to its initial value on the next zwp_input_method_v2.done\nevent.\n\nThe initial value of cause is input_method."] TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause , } , # [doc = "content purpose and hint\n\nIndicates the content type and hint for the current\nzwp_input_method_v2 instance.\n\nValues set with this event are double-buffered. They will get applied\non the next zwp_input_method_v2.done event.\n\nThe initial value for hint is none, and the initial value for purpose\nis normal."] ContentType { hint : super :: zwp_text_input_v3 :: ContentHint , purpose : super :: zwp_text_input_v3 :: ContentPurpose , } , # [doc = "apply state\n\nAtomically applies state changes recently sent to the client.\n\nThe done event establishes and updates the state of the client, and\nmust be issued after any changes to apply them.\n\nText input state (content purpose, content hint, surrounding text, and\nchange cause) is conceptually double-buffered within an input method\ncontext.\n\nEvents modify the pending state, as opposed to the current state in use\nby the input method. A done event atomically applies all pending state,\nreplacing the current state. After done, the new pending state is as\ndocumented for each related request.\n\nEvents must be applied in the order of arrival.\n\nNeither current nor pending state are modified unless noted otherwise."] Done , # [doc = "input method unavailable\n\nThe input method ceased to be available.\n\nThe compositor must issue this event as the only event on the object if\nthere was another input_method object associated with the same seat at\nthe time of its creation.\n\nThe compositor must issue this request when the object is no longer\nusable, e.g. due to seat removal.\n\nThe input method context becomes inert and should be destroyed after\ndeactivation is handled. Any further requests and events except for the\ndestroy request must be ignored."] Unavailable , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "activate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "deactivate" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "surrounding_text" , since : 1 , signature : & [super :: ArgumentType :: Str , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "text_change_cause" , since : 1 , signature : & [super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "content_type" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "done" , since : 1 , signature : & [] , destructor : false , } , super :: MessageDesc { name : "unavailable" , since : 1 , signature : & [] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Activate => 0 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 2 , Event :: TextChangeCause { .. } => 3 , Event :: ContentType { .. } => 4 , Event :: Done => 5 , Event :: Unavailable => 6 , } } fn since (& self) -> u32 { match * self { Event :: Activate => 1 , Event :: Deactivate => 1 , Event :: SurroundingText { .. } => 1 , Event :: TextChangeCause { .. } => 1 , Event :: ContentType { .. } => 1 , Event :: Done => 1 , Event :: Unavailable => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => Ok (Event :: Activate) , 1 => Ok (Event :: Deactivate) , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: SurroundingText { text : { if let Some (Argument :: Str (val)) = args . next () { let s = String :: from_utf8 (val . into_bytes ()) . unwrap_or_else (| e | String :: from_utf8_lossy (& e . into_bytes ()) . into ()) ; s } else { return Err (()) ; } } , cursor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , anchor : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextChangeCause { cause : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ChangeCause :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 4 => { let mut args = msg . args . into_iter () ; Ok (Event :: ContentType { hint : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentHint :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , purpose : { if let Some (Argument :: Uint (val)) = args . next () { super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 5 => Ok (Event :: Done) , 6 => Ok (Event :: Unavailable) , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { Ok (Event :: Activate) } , 1 => { Ok (Event :: Deactivate) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: SurroundingText { text : :: std :: ffi :: CStr :: from_ptr (_args [0] . s) . to_string_lossy () . into_owned () , cursor : _args [1] . u , anchor : _args [2] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 1) ; Ok (Event :: TextChangeCause { cause : super :: zwp_text_input_v3 :: ChangeCause :: from_raw (_args [0] . u) . ok_or (()) ? , }) } , 4 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: ContentType { hint : super :: zwp_text_input_v3 :: ContentHint :: from_raw (_args [0] . u) . ok_or (()) ? , purpose : super :: zwp_text_input_v3 :: ContentPurpose :: from_raw (_args [1] . u) . ok_or (()) ? , }) } , 5 => { Ok (Event :: Done) } , 6 => { Ok (Event :: Unavailable) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodV2 (Proxy < ZwpInputMethodV2 >) ; impl AsRef < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodV2 >> for ZwpInputMethodV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodV2 (value) } } impl From < ZwpInputMethodV2 > for Proxy < ZwpInputMethodV2 > { # [inline] fn from (value : ZwpInputMethodV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_v2_interface } } } impl ZwpInputMethodV2 { # [doc = "commit string\n\nSend the commit string text for insertion to the application.\n\nInserts a string at current cursor position (see commit event\nsequence). The string to commit could be either just a single character\nafter a key press or the result of some composing.\n\nThe argument text is a buffer containing the string to insert. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_text_input_v3.commit request.\n\nThe initial value of text is an empty string."] pub fn commit_string (& self , text : String) -> () { let msg = Request :: CommitString { text : text } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "pre-edit string\n\nSend the pre-edit string text to the application text input.\n\nPlace a new composing text (pre-edit) at the current cursor position.\nAny previously set composing text must be removed. Any previously\nexisting selected text must be removed. The cursor is moved to a new\nposition within the preedit string.\n\nThe argument text is a buffer containing the preedit string. There is\na maximum length of wayland messages, so text can not be longer than\n4000 bytes.\n\nThe arguments cursor_begin and cursor_end are counted in bytes relative\nto the beginning of the submitted string buffer. Cursor should be\nhidden by the text input when both are equal to -1.\n\ncursor_begin indicates the beginning of the cursor. cursor_end\nindicates the end of the cursor. It may be equal or different than\ncursor_begin.\n\nValues set with this event are double-buffered. They must be applied on\nthe next zwp_input_method_v2.commit event.\n\nThe initial value of text is an empty string. The initial value of\ncursor_begin, and cursor_end are both 0."] pub fn set_preedit_string (& self , text : String , cursor_begin : i32 , cursor_end : i32) -> () { let msg = Request :: SetPreeditString { text : text , cursor_begin : cursor_begin , cursor_end : cursor_end } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "delete text\n\nRemove the surrounding text.\n\nbefore_length and after_length are the number of bytes before and after\nthe current cursor index (excluding the preedit text) to delete.\n\nIf any preedit text is present, it is replaced with the cursor for the\npurpose of this event. In effect before_length is counted from the\nbeginning of preedit text, and after_length from its end (see commit\nevent sequence).\n\nValues set with this event are double-buffered. They must be applied\nand reset to initial on the next zwp_input_method_v2.commit request.\n\nThe initial values of both before_length and after_length are 0."] pub fn delete_surrounding_text (& self , before_length : u32 , after_length : u32) -> () { let msg = Request :: DeleteSurroundingText { before_length : before_length , after_length : after_length } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "apply state\n\nApply state changes from commit_string, set_preedit_string and\ndelete_surrounding_text requests.\n\nThe state relating to these events is double-buffered, and each one\nmodifies the pending state. This request replaces the current state\nwith the pending state.\n\nThe connected text input is expected to proceed by evaluating the\nchanges in the following order:\n\n1. Replace existing preedit string with the cursor.\n2. Delete requested surrounding text.\n3. Insert commit string with the cursor at its end.\n4. Calculate surrounding text to send.\n5. Insert new preedit text in cursor position.\n6. Place cursor inside preedit text.\n\nThe serial number reflects the last state of the zwp_input_method_v2\nobject known to the client. The value of the serial argument must be\nequal to the number of done events already issued by that object. When\nthe compositor receives a commit request with a serial different than\nthe number of past done events, it must proceed as normal, except it\nshould not change the current state of the zwp_input_method_v2 object."] pub fn commit (& self , serial : u32) -> () { let msg = Request :: Commit { serial : serial } ; self . 0 . send :: < AnonymousObject > (msg , None) ; } # [doc = "create popup surface\n\nCreates a new zwp_input_popup_surface_v2 object wrapping a given\nsurface.\n\nThe surface gets assigned the \"input_popup\" role. If the surface\nalready has an assigned role, the compositor must issue a protocol\nerror."] pub fn get_input_popup_surface (& self , surface : & super :: wl_surface :: WlSurface) -> Main < super :: zwp_input_popup_surface_v2 :: ZwpInputPopupSurfaceV2 > { let msg = Request :: GetInputPopupSurface { surface : surface . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "grab hardware keyboard\n\nAllow an input method to receive hardware keyboard input and process\nkey events to generate text events (with pre-edit) over the wire. This\nallows input methods which compose multiple key events for inputting\ntext like it is done for CJK languages.\n\nThe compositor should send all keyboard events on the seat to the grab\nholder via the returned wl_keyboard object. Nevertheless, the\ncompositor may decide not to forward any particular event. The\ncompositor must not further process any event after it has been\nforwarded to the grab holder.\n\nReleasing the resulting wl_keyboard object releases the grab."] pub fn grab_keyboard (& self ,) -> Main < super :: zwp_input_method_keyboard_grab_v2 :: ZwpInputMethodKeyboardGrabV2 > { let msg = Request :: GrabKeyboard { } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the text input\n\nDestroys the zwp_text_input_v2 object and any associated child\nobjects, i.e. zwp_input_popup_surface_v2 and\nzwp_input_method_keyboard_grab_v2.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_SET_PREEDIT_STRING_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DELETE_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_COMMIT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_POPUP_SURFACE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_GRAB_KEYBOARD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_ACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DEACTIVATE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_SURROUNDING_TEXT_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_CHANGE_CAUSE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_CONTENT_TYPE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_DONE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_UNAVAILABLE_SINCE : u32 = 1u32 ; static mut zwp_input_method_v2_requests_get_input_popup_surface_types : [* const wl_interface ; 2] = [unsafe { & super :: zwp_input_popup_surface_v2 :: zwp_input_popup_surface_v2_interface as * const wl_interface } , unsafe { & super :: wl_surface :: wl_surface_interface as * const wl_interface } ,] ; static mut zwp_input_method_v2_requests_grab_keyboard_types : [* const wl_interface ; 1] = [unsafe { & super :: zwp_input_method_keyboard_grab_v2 :: zwp_input_method_keyboard_grab_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_requests : [wl_message ; 7] = [wl_message { name : b"commit_string\0" as * const u8 as * const c_char , signature : b"s\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"set_preedit_string\0" as * const u8 as * const c_char , signature : b"sii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"delete_surrounding_text\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"commit\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"get_input_popup_surface\0" as * const u8 as * const c_char , signature : b"no\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_get_input_popup_surface_types as * const _ } , } , wl_message { name : b"grab_keyboard\0" as * const u8 as * const c_char , signature : b"n\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_v2_requests_grab_keyboard_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_v2_events : [wl_message ; 7] = [wl_message { name : b"activate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"deactivate\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"surrounding_text\0" as * const u8 as * const c_char , signature : b"suu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"text_change_cause\0" as * const u8 as * const c_char , signature : b"u\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"content_type\0" as * const u8 as * const c_char , signature : b"uu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"done\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"unavailable\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 7 , requests : unsafe { & zwp_input_method_v2_requests as * const _ } , event_count : 7 , events : unsafe { & zwp_input_method_v2_events as * const _ } , } ; } # [doc = "popup surface\n\nThis interface marks a surface as a popup for interacting with an input\nmethod.\n\nThe compositor should place it near the active text input area. It must\nbe visible if and only if the input method is in the active state.\n\nThe client must not destroy the underlying wl_surface while the\nzwp_input_popup_surface_v2 object exists."] pub mod zwp_input_popup_surface_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "This is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , } } fn opcode (& self) -> u16 { match * self { Request :: Destroy => 0 , } } fn since (& self) -> u32 { match * self { Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Destroy => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "set text input area position\n\nNotify about the position of the area of the text input expressed as a\nrectangle in surface local coordinates.\n\nThis is a hint to the input method telling it the relative position of\nthe text being entered."] TextInputRectangle { x : i32 , y : i32 , width : i32 , height : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "text_input_rectangle" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: TextInputRectangle { .. } => 0 , } } fn since (& self) -> u32 { match * self { Event :: TextInputRectangle { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: TextInputRectangle { x : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , y : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , width : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , height : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: TextInputRectangle { x : _args [0] . i , y : _args [1] . i , width : _args [2] . i , height : _args [3] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputPopupSurfaceV2 (Proxy < ZwpInputPopupSurfaceV2 >) ; impl AsRef < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputPopupSurfaceV2 >> for ZwpInputPopupSurfaceV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputPopupSurfaceV2 (value) } } impl From < ZwpInputPopupSurfaceV2 > for Proxy < ZwpInputPopupSurfaceV2 > { # [inline] fn from (value : ZwpInputPopupSurfaceV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputPopupSurfaceV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputPopupSurfaceV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_popup_surface_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_popup_surface_v2_interface } } } impl ZwpInputPopupSurfaceV2 { # [doc = "This is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_TEXT_INPUT_RECTANGLE_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_requests : [wl_message ; 1] = [wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_events : [wl_message ; 1] = [wl_message { name : b"text_input_rectangle\0" as * const u8 as * const c_char , signature : b"iiii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_popup_surface_v2_interface : wl_interface = wl_interface { name : b"zwp_input_popup_surface_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_popup_surface_v2_requests as * const _ } , event_count : 1 , events : unsafe { & zwp_input_popup_surface_v2_events as * const _ } , } ; } # [doc = "keyboard grab\n\nThe zwp_input_method_keyboard_grab_v2 interface represents an exclusive\ngrab of the wl_keyboard interface associated with the seat."] pub mod zwp_input_method_keyboard_grab_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "release the grab object\n\n\n\nThis is a destructor, once sent this object cannot be used any longer."] Release , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "release" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Release => true , } } fn opcode (& self) -> u16 { match * self { Request :: Release => 0 , } } fn since (& self) -> u32 { match * self { Request :: Release => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: Release => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: Release => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (0 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { # [doc = "keyboard mapping\n\nThis event provides a file descriptor to the client which can be\nmemory-mapped to provide a keyboard mapping description."] Keymap { format : super :: wl_keyboard :: KeymapFormat , fd : :: std :: os :: unix :: io :: RawFd , size : u32 , } , # [doc = "key event\n\nA key was pressed or released.\nThe time argument is a timestamp with millisecond granularity, with an\nundefined base."] Key { serial : u32 , time : u32 , key : u32 , state : super :: wl_keyboard :: KeyState , } , # [doc = "modifier and group state\n\nNotifies clients that the modifier and/or group state has changed, and\nit should update its local state."] Modifiers { serial : u32 , mods_depressed : u32 , mods_latched : u32 , mods_locked : u32 , group : u32 , } , # [doc = "repeat rate and delay\n\nInforms the client about the keyboard's repeat rate and delay.\n\nThis event is sent as soon as the zwp_input_method_keyboard_grab_v2\nobject has been created, and is guaranteed to be received by the\nclient before any key press event.\n\nNegative values for either rate or delay are illegal. A rate of zero\nwill disable any repeating (regardless of the value of delay).\n\nThis event can be sent later on as well with a new value if necessary,\nso clients should continue listening for the event past the creation\nof zwp_input_method_keyboard_grab_v2."] RepeatInfo { rate : i32 , delay : i32 , } , } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "keymap" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Fd , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "key" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "modifiers" , since : 1 , signature : & [super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint , super :: ArgumentType :: Uint ,] , destructor : false , } , super :: MessageDesc { name : "repeat_info" , since : 1 , signature : & [super :: ArgumentType :: Int , super :: ArgumentType :: Int ,] , destructor : false , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { _ => false , } } fn opcode (& self) -> u16 { match * self { Event :: Keymap { .. } => 0 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 2 , Event :: RepeatInfo { .. } => 3 , } } fn since (& self) -> u32 { match * self { Event :: Keymap { .. } => 1 , Event :: Key { .. } => 1 , Event :: Modifiers { .. } => 1 , Event :: RepeatInfo { .. } => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { 0 => { let mut args = msg . args . into_iter () ; Ok (Event :: Keymap { format : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeymapFormat :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , fd : { if let Some (Argument :: Fd (val)) = args . next () { val } else { return Err (()) ; } } , size : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 1 => { let mut args = msg . args . into_iter () ; Ok (Event :: Key { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , time : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , key : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , state : { if let Some (Argument :: Uint (val)) = args . next () { super :: wl_keyboard :: KeyState :: from_raw (val) . ok_or (()) ? } else { return Err (()) ; } } , }) } , 2 => { let mut args = msg . args . into_iter () ; Ok (Event :: Modifiers { serial : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_depressed : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_latched : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , mods_locked : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , group : { if let Some (Argument :: Uint (val)) = args . next () { val } else { return Err (()) ; } } , }) } , 3 => { let mut args = msg . args . into_iter () ; Ok (Event :: RepeatInfo { rate : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , delay : { if let Some (Argument :: Int (val)) = args . next () { val } else { return Err (()) ; } } , }) } , _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { 0 => { let _args = :: std :: slice :: from_raw_parts (args , 3) ; Ok (Event :: Keymap { format : super :: wl_keyboard :: KeymapFormat :: from_raw (_args [0] . u) . ok_or (()) ? , fd : _args [1] . h , size : _args [2] . u , }) } , 1 => { let _args = :: std :: slice :: from_raw_parts (args , 4) ; Ok (Event :: Key { serial : _args [0] . u , time : _args [1] . u , key : _args [2] . u , state : super :: wl_keyboard :: KeyState :: from_raw (_args [3] . u) . ok_or (()) ? , }) } , 2 => { let _args = :: std :: slice :: from_raw_parts (args , 5) ; Ok (Event :: Modifiers { serial : _args [0] . u , mods_depressed : _args [1] . u , mods_latched : _args [2] . u , mods_locked : _args [3] . u , group : _args [4] . u , }) } , 3 => { let _args = :: std :: slice :: from_raw_parts (args , 2) ; Ok (Event :: RepeatInfo { rate : _args [0] . i , delay : _args [1] . i , }) } , _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodKeyboardGrabV2 (Proxy < ZwpInputMethodKeyboardGrabV2 >) ; impl AsRef < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodKeyboardGrabV2 >> for ZwpInputMethodKeyboardGrabV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodKeyboardGrabV2 (value) } } impl From < ZwpInputMethodKeyboardGrabV2 > for Proxy < ZwpInputMethodKeyboardGrabV2 > { # [inline] fn from (value : ZwpInputMethodKeyboardGrabV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodKeyboardGrabV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodKeyboardGrabV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_keyboard_grab_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_keyboard_grab_v2_interface } } } impl ZwpInputMethodKeyboardGrabV2 { # [doc = "release the grab object\n\n\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn release (& self ,) -> () { let msg = Request :: Release ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_RELEASE_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEYMAP_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_KEY_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_MODIFIERS_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this event"] pub const EVT_REPEAT_INFO_SINCE : u32 = 1u32 ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_requests : [wl_message ; 1] = [wl_message { name : b"release\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_events : [wl_message ; 4] = [wl_message { name : b"keymap\0" as * const u8 as * const c_char , signature : b"uhu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"key\0" as * const u8 as * const c_char , signature : b"uuuu\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * const c_char , signature : b"uuuuu\0" as * const u8 as * const c_char , types : unsafe { addr_of!(types_null) as * const _ } , } , wl_message { name : b"repeat_info\0" as * const u8 as * const c_char , signature : b"ii\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_keyboard_grab_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_keyboard_grab_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 1 , requests : unsafe { & zwp_input_method_keyboard_grab_v2_requests as * const _ } , event_count : 4 , events : unsafe { & zwp_input_method_keyboard_grab_v2_events as * const _ } , } ; } # [doc = "input method manager\n\nThe input method manager allows the client to become the input method on\na chosen seat.\n\nNo more than one input method must be associated with any seat at any\ngiven time."] pub mod zwp_input_method_manager_v2 { use std :: os :: raw :: c_char ; use super :: { Proxy , AnonymousObject , Interface , MessageGroup , MessageDesc , ArgumentType , Object , Message , Argument , ObjectMetadata , types_null , NULLPTR , Main , smallvec , } ; use super :: sys :: common :: { wl_interface , wl_array , wl_argument , wl_message } ; use super :: sys :: client :: * ; # [derive (Debug)] # [non_exhaustive] pub enum Request { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] GetInputMethod { seat : super :: wl_seat :: WlSeat , } , # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, once sent this object cannot be used any longer."] Destroy , } impl super :: MessageGroup for Request { const MESSAGES : & 'static [super :: MessageDesc] = & [super :: MessageDesc { name : "get_input_method" , since : 1 , signature : & [super :: ArgumentType :: Object , super :: ArgumentType :: NewId ,] , destructor : false , } , super :: MessageDesc { name : "destroy" , since : 1 , signature : & [] , destructor : true , } ,] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { Request :: Destroy => true , _ => false , } } fn opcode (& self) -> u16 { match * self { Request :: GetInputMethod { .. } => 0 , Request :: Destroy => 1 , } } fn since (& self) -> u32 { match * self { Request :: GetInputMethod { .. } => 1 , Request :: Destroy => 1 , } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { 0 => Some (Object :: from_interface :: < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > (version , meta . child () ,)) , _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { panic ! ("Request::from_raw can not be used Client-side.") } fn into_raw (self , sender_id : u32) -> Message { match self { Request :: GetInputMethod { seat } => Message { sender_id : sender_id , opcode : 0 , args : smallvec ! [Argument :: Object (seat . as_ref () . id ()) , Argument :: NewId (0) ,] , } , Request :: Destroy => Message { sender_id : sender_id , opcode : 1 , args : smallvec ! [] , } , } } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Request , () > { panic ! ("Request::from_raw_c can not be used Client-side.") } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { match self { Request :: GetInputMethod { seat } => { let mut _args_array : [wl_argument ; 2] = unsafe { :: std :: mem :: zeroed () } ; _args_array [0] . o = seat . as_ref () . c_ptr () as * mut _ ; _args_array [1] . o = :: std :: ptr :: null_mut () as * mut _ ; f (0 , & mut _args_array) } , Request :: Destroy => { let mut _args_array : [wl_argument ; 0] = unsafe { :: std :: mem :: zeroed () } ; f (1 , & mut _args_array) } , } } } # [derive (Debug)] # [non_exhaustive] pub enum Event { } impl super :: MessageGroup for Event { const MESSAGES : & 'static [super :: MessageDesc] = & [] ; type Map = super :: ProxyMap ; fn is_destructor (& self) -> bool { match * self { } } fn opcode (& self) -> u16 { match * self { } } fn since (& self) -> u32 { match * self { } } fn child < Meta : ObjectMetadata > (opcode : u16 , version : u32 , meta : & Meta) -> Option < Object < Meta >> { match opcode { _ => None , } } fn from_raw (msg : Message , map : & mut Self :: Map) -> Result < Self , () > { match msg . opcode { _ => Err (()) , } } fn into_raw (self , sender_id : u32) -> Message { panic ! ("Event::into_raw can not be used Client-side.") } unsafe fn from_raw_c (obj : * mut :: std :: os :: raw :: c_void , opcode : u32 , args : * const wl_argument ,) -> Result < Event , () > { match opcode { _ => return Err (()) , } } fn as_raw_c_in < F , T > (self , f : F) -> T where F : FnOnce (u32 , & mut [wl_argument]) -> T { panic ! ("Event::as_raw_c_in can not be used Client-side.") } } # [derive (Clone , Eq , PartialEq)] pub struct ZwpInputMethodManagerV2 (Proxy < ZwpInputMethodManagerV2 >) ; impl AsRef < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn as_ref (& self) -> & Proxy < Self > { & self . 0 } } impl From < Proxy < ZwpInputMethodManagerV2 >> for ZwpInputMethodManagerV2 { # [inline] fn from (value : Proxy < Self >) -> Self { ZwpInputMethodManagerV2 (value) } } impl From < ZwpInputMethodManagerV2 > for Proxy < ZwpInputMethodManagerV2 > { # [inline] fn from (value : ZwpInputMethodManagerV2) -> Self { value . 0 } } impl std :: fmt :: Debug for ZwpInputMethodManagerV2 { fn fmt (& self , f : & mut std :: fmt :: Formatter < '_ >) -> std :: fmt :: Result { f . write_fmt (format_args ! ("{:?}" , self . 0)) } } impl Interface for ZwpInputMethodManagerV2 { type Request = Request ; type Event = Event ; const NAME : & 'static str = "zwp_input_method_manager_v2" ; const VERSION : u32 = 1 ; fn c_interface () -> * const wl_interface { unsafe { & zwp_input_method_manager_v2_interface } } } impl ZwpInputMethodManagerV2 { # [doc = "request an input method object\n\nRequest a new input zwp_input_method_v2 object associated with a given\nseat."] pub fn get_input_method (& self , seat : & super :: wl_seat :: WlSeat) -> Main < super :: zwp_input_method_v2 :: ZwpInputMethodV2 > { let msg = Request :: GetInputMethod { seat : seat . clone () } ; self . 0 . send (msg , None) . unwrap () } # [doc = "destroy the input method manager\n\nDestroys the zwp_input_method_manager_v2 object.\n\nThe zwp_input_method_v2 objects originating from it remain valid.\n\nThis is a destructor, you cannot send requests to this object any longer once this method is called."] pub fn destroy (& self ,) -> () { let msg = Request :: Destroy ; self . 0 . send :: < AnonymousObject > (msg , None) ; } } # [doc = r" The minimal object version supporting this request"] pub const REQ_GET_INPUT_METHOD_SINCE : u32 = 1u32 ; # [doc = r" The minimal object version supporting this request"] pub const REQ_DESTROY_SINCE : u32 = 1u32 ; static mut zwp_input_method_manager_v2_requests_get_input_method_types : [* const wl_interface ; 2] = [unsafe { & super :: wl_seat :: wl_seat_interface as * const wl_interface } , unsafe { & super :: zwp_input_method_v2 :: zwp_input_method_v2_interface as * const wl_interface } ,] ; # [doc = r" C-representation of the messages of this interface, for interop"] pub static mut zwp_input_method_manager_v2_requests : [wl_message ; 2] = [wl_message { name : b"get_input_method\0" as * const u8 as * const c_char , signature : b"on\0" as * const u8 as * const c_char , types : unsafe { & zwp_input_method_manager_v2_requests_get_input_method_types as * const _ } , } , wl_message { name : b"destroy\0" as * const u8 as * const c_char , signature : b"\0" as * const u8 as * const c_char , types : unsafe { & types_null as * const _ } , } ,] ; # [doc = r" C representation of this interface, for interop"] pub static mut zwp_input_method_manager_v2_interface : wl_interface = wl_interface { name : b"zwp_input_method_manager_v2\0" as * const u8 as * const c_char , version : 1 , request_count : 2 , requests : unsafe { & zwp_input_method_manager_v2_requests as * const _ } , event_count : 0 , events : NULLPTR as * const wl_message , } ; } [INFO] [stdout] | ~~~~~~~~~ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a shared reference to mutable static is discouraged [INFO] [stdout] --> /opt/rustwide/target/debug/build/zwp-input-method-ddc30199f5203da0/out/input_method_api.rs:1:53455 [INFO] [stdout] | [INFO] [stdout] 1 | ...st u8 as * const c_char , types : unsafe { & types_null as * const _ } , } , wl_message { name : b"modifiers\0" as * const u8 as * con... [INFO] [stdout] | ^^^^^^^^^^^^ shared reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see issue #114447 [INFO] [stdout] = note: this will be a hard error in the 2024 edition [INFO] [stdout] = note: this shared reference has lifetime `'static`, but if the static ever gets mutated, or a mutable reference is created, then any further use of this shared reference is Undefined Behavior [INFO] [stdout] help: use `addr_of!` instead to create a raw pointer [INFO] [stdout] | [WARN] too much data in the log, truncating it