flt
is a Flutter Terminal Embedder, implementing the Flutter Engine's Custom Embedder API.
This embedder draws to the current terminal window using ANSI Escape Codes to create a Text-based user interface.
flt.demo.mp4
Mainly for fun to learn Rust and more about the Flutter Engine. It can also be a quick playground for Flutter without platform-specific or GUI specific dependencies; only a terminal is needed and it can even be used over SSH.
This was mainly developed on WSL Linux using the Windows Terminal. It also works on Linux and iTerm2 on macOS. YMMV with other terminal emulators, though it might just work as interfacing with the terminal is done through a cross-platform library.
Not working yet:
- Windows
- Terminal.app on macOS
This project uses submodules, so pass the --recurse-submodules
flag.
git clone --recurse-submodules git@github.com:jiahaog/flt.git
Install Rust first, then at the root of the monorepo, the following command will build the Sample Flutter App, and run it with the terminal embedder.
cargo run
cargo run -- <path to the root of your flutter project>
# See help for `flt-cli`.
cargo run -- --help
# See help for `flt`.
cargo run -- --args=--help
flt
- The terminal embedder.flt-cli
- A small CLI utility to make local development easier. By default, thecargo run
command at the root of the repository will run this.flutter-sys
- Safe Rust bindings to the Flutter Embedder API.sample_app
- A sample Flutter Project used for local development.third_party/flutter
- A submodule checkout of the Flutter Framework.
- Windows support
- Fix Terminal.app support on macOS
- Keyboard support
- Slow performance
- Improve semantic label positions