[package] name = "crossterm" version = "0.29.0" authors = ["T. Post"] description = "A crossplatform terminal library for manipulating terminals." repository = "https://github.com/crossterm-rs/crossterm" documentation = "https://docs.rs/crossterm/" license = "MIT" keywords = ["event", "color", "cli", "input", "terminal"] exclude = ["target", "Cargo.lock"] readme = "README.md" edition = "2021" rust-version = "1.63.0" categories = ["command-line-interface", "command-line-utilities"] [lib] name = "crossterm" path = "src/lib.rs" [package.metadata.docs.rs] all-features = true [features] default = ["bracketed-paste", "events", "windows", "derive-more"] #! ### Default features ## Enables triggering [`Event::Paste`](event::Event::Paste) when pasting text into the terminal. bracketed-paste = [] ## Enables reading input/events from the system using the [`event`] module. events = ["dep:mio", "dep:signal-hook", "dep:signal-hook-mio"] ## Enables windows specific crates. windows = ["dep:winapi", "dep:crossterm_winapi"] #! ### Optional Features ## Enables the [EventStream](event::EventStream) struct for async event reading. event-stream = ["dep:futures-core", "events"] ## Enables [`serde`] for various types. serde = ["dep:serde", "bitflags/serde"] ## Enables raw file descriptor polling / selecting instead of mio. use-dev-tty = ["filedescriptor", "rustix/process"] ## Enables `is_*` helper functions for event enums. derive-more = ["dep:derive_more"] ## Enables interacting with a host clipboard via [`clipboard`](clipboard/index.html) osc52 = ["dep:base64"] [dependencies] base64 = { version = "0.22", optional = true } bitflags = { version = "2.9" } derive_more = { version = "2.0.0", features = ["is_variant"], optional = true } document-features = "0.2.11" futures-core = { version = "0.3", optional = true, default-features = false } parking_lot = "0.12" serde = { version = "1.0", features = ["derive"], optional = true } # Windows dependencies [target.'cfg(windows)'.dependencies] crossterm_winapi = { version = "0.9.1", optional = true } winapi = { version = "0.3.9", optional = true, features = ["winuser", "winerror"] } # UNIX dependencies [target.'cfg(unix)'.dependencies] filedescriptor = { version = "0.8", optional = true } # Default to using rustix for UNIX systems, but provide an option to use libc for backwards # compatibility. libc = { version = "0.2", default-features = false, optional = true } mio = { version = "1.0", features = ["os-poll"], optional = true } rustix = { version = "1", default-features = false, features = ["std", "stdio", "termios"] } signal-hook = { version = "0.3.17", optional = true } signal-hook-mio = { version = "0.2.4", features = ["support-v1_0"], optional = true } [dev-dependencies] async-std = "1.13" futures = "0.3" futures-timer = "3.0" serde_json = "1.0" serial_test = "3.0.0" temp-env = "0.3.6" tokio = { version = "1.44", features = ["full"] } # Examples [[example]] name = "event-read" required-features = ["bracketed-paste", "events"] [[example]] name = "event-match-modifiers" required-features = ["bracketed-paste", "events"] [[example]] name = "event-poll-read" required-features = ["bracketed-paste", "events"] [[example]] name = "event-stream-async-std" required-features = ["event-stream", "events"] [[example]] name = "event-stream-tokio" required-features = ["event-stream", "events"] [[example]] name = "event-read-char-line" required-features = ["events"] [[example]] name = "stderr" required-features = ["events"] [[example]] name = "key-display" required-features = ["events"] [[example]] name = "copy-to-clipboard" required-features = ["osc52"]