28 releases (15 breaking)
Uses new Rust 2024
| 0.17.1 | Jan 25, 2026 |
|---|---|
| 0.16.0 | Nov 10, 2025 |
| 0.14.1 | Jun 28, 2025 |
| 0.13.1 | Jan 3, 2025 |
| 0.2.1 | Jun 4, 2021 |
#81 in Game dev
616 downloads per month
Used in 2 crates
98KB
1.5K
SLoC
bevy_console
A simple Half-Life inspired console with support for argument parsing powered by clap.
Features
- Command parsing with
clap - Command history
- Command completion
- Support for ansi colors
- Customizable key bindings
- Customizable theme
- Supports capturing Bevy logs to console
Usage
Add ConsolePlugin and optionally the resource ConsoleConfiguration.
use bevy::prelude::*;
use bevy_console::{ConsoleConfiguration, ConsolePlugin};
fn main() {
App::new()
.add_plugins((DefaultPlugins, ConsolePlugin))
.insert_resource(ConsoleConfiguration {
// override config here
..Default::default()
});
}
Create a console command struct and system and add it to your app with .add_console_command.
Commands are created like clap commands with an additional CommandName trait derived via the ConsoleCommand derive.
Add doc comments to your command to provide help information in the console.
use bevy::prelude::*;
use bevy_console::{reply, AddConsoleCommand, ConsoleCommand, ConsolePlugin};
use clap::Parser;
fn main() {
App::new()
.add_plugins((DefaultPlugins, ConsolePlugin))
.add_console_command::<ExampleCommand, _>(example_command);
}
/// Example command
#[derive(Parser, ConsoleCommand)]
#[command(name = "example")]
struct ExampleCommand {
/// Some message
msg: String,
}
fn example_command(mut log: ConsoleCommand<ExampleCommand>) {
if let Some(Ok(ExampleCommand { msg })) = log.take() {
// handle command
}
}
Examples can be found in the /examples directory.
cargo run --example log_command
wasm
Should work in wasm, but you need to disable default features.
Keyboard Shortcuts
Some shortcuts:
- Ctrl + L: Clear history
- Ctrl + C: Clear line
- Tab: Line completion
Dependencies
~70–115MB
~2M SLoC