Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/p4ymak/egui_code_editor
egui Code Editor widget with numbered lines and syntax highlighting..
https://github.com/p4ymak/egui_code_editor
Last synced: 4 months ago
JSON representation
egui Code Editor widget with numbered lines and syntax highlighting..
- Host: GitHub
- URL: https://github.com/p4ymak/egui_code_editor
- Owner: p4ymak
- Created: 2023-07-17T11:54:22.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-27T09:54:00.000Z (5 months ago)
- Last Synced: 2024-10-31T12:15:47.608Z (4 months ago)
- Language: Rust
- Homepage: https://www.donationalerts.com/r/p4ymak
- Size: 457 KB
- Stars: 46
- Watchers: 2
- Forks: 16
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-egui - egui code editor widget
README
# Egui Code Editor
Text Editor Widget for [egui](https://github.com/emilk/egui) with numbered lines and simple syntax highlighting based on keywords sets.
## Usage with egui
```rust
use egui_code_editor::{CodeEditor, ColorTheme, Syntax};CodeEditor::default()
.id_source("code editor")
.with_rows(12)
.with_fontsize(14.0)
.with_theme(ColorTheme::GRUVBOX)
.with_syntax(Syntax::rust())
.with_numlines(true)
.show(ui, &mut self.code);
```## Usage as lexer without egui
**Cargo.toml**
```toml
[dependencies]
egui_code_editor = { version = "0.2" , default-features = false }
colorful = "0.2.2"
```**main.rs**
```rust
use colorful::{Color, Colorful};
use egui_code_editor::{Syntax, Token, TokenType};fn color(token: TokenType) -> Color {
match token {
TokenType::Comment(_) => Color::Grey37,
TokenType::Function => Color::Yellow3b,
TokenType::Keyword => Color::IndianRed1c,
TokenType::Literal => Color::NavajoWhite1,
TokenType::Numeric(_) => Color::MediumPurple,
TokenType::Punctuation(_) => Color::Orange3,
TokenType::Special => Color::Cyan,
TokenType::Str(_) => Color::Green,
TokenType::Type => Color::GreenYellow,
TokenType::Whitespace(_) => Color::White,
TokenType::Unknown => Color::Pink1,
}
}fn main() {
let text = r#"// Code Editor
CodeEditor::default()
.id_source("code editor")
.with_rows(12)
.with_fontsize(14.0)
.with_theme(self.theme)
.with_syntax(self.syntax.to_owned())
.with_numlines(true)
.vscroll(true)
.show(ui, &mut self.code);
"#;let syntax = Syntax::rust();
for token in Token::default().tokens(&syntax, text) {
print!("{}", token.buffer().color(color(token.ty())));
}
}
```## Themes
Based on themes in [Helix Editor](https://github.com/helix-editor/helix).
Font used in examples is [Comic Code](https://tosche.net/fonts/comic-code) by Toshi Omagari.
### Ayu
data:image/s3,"s3://crabby-images/fc0b3/fc0b3fb0fd829278cc3454faa186dd03f27c2fac" alt="Ayu"### Ayu Dark
data:image/s3,"s3://crabby-images/b4978/b497883bdab1119071ad3e19430b6bf9a16d3fbf" alt="Ayu Dark"### Ayu Mirage
data:image/s3,"s3://crabby-images/9636d/9636dd3d7570af3835c7d2c3a0bd1582406e9481" alt="Ayu Mirage"### Github Dark
data:image/s3,"s3://crabby-images/61c0d/61c0d888372acdca06821a2d76cea94dc888d470" alt="Github Dark"### Github Light
data:image/s3,"s3://crabby-images/cf53d/cf53d5e7504d97c4a66bb283acc668563a5a9d70" alt="Github Light"### Gruvbox
data:image/s3,"s3://crabby-images/7f7ab/7f7ab0240ce9f036ec2821a19e85c0137f5a0597" alt="Gruvbox"### Gruvbox Light
data:image/s3,"s3://crabby-images/6a0d2/6a0d2d042f15288a444f56629c699de8a503b77c" alt="Gruvbox Light"### Sonokai
data:image/s3,"s3://crabby-images/35e41/35e41daccaefa204ce5792a09136f88625b97f18" alt="Sonokai"