Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/katyo/clex

Fast and robust C source lexer in Rust
https://github.com/katyo/clex

Last synced: 2 months ago
JSON representation

Fast and robust C source lexer in Rust

Awesome Lists containing this project

README

        

# C source lexer in Rust

[![github](https://img.shields.io/badge/github-katyo/clex-8da0cb.svg?style=for-the-badge&logo=github)](https://github.com/katyo/clex)
[![crate](https://img.shields.io/crates/v/clex.svg?style=for-the-badge&color=fc8d62&logo=rust)](https://crates.io/crates/clex)
[![docs](https://img.shields.io/badge/docs.rs-clex-66c2a5?style=for-the-badge&logo=)](https://docs.rs/clex)
[![MIT](https://img.shields.io/badge/License-MIT-brightgreen.svg?style=for-the-badge)](https://opensource.org/licenses/MIT)
[![CI](https://img.shields.io/github/workflow/status/katyo/clex/Rust?style=for-the-badge&logo=github-actions&logoColor=white)](https://github.com/katyo/clex/actions?query=workflow%3ARust)

This is a fast and robust C source lexer in Rust. For example it can be used to extract some metadata from sources like comments or strings.

## Library usage

```rust
use clex::{Lexer, Token};

let src = r#"
static const char *s = "world";

int main() {
// Hello world
printf("Hello %s\n", s);

return 0;
}
"#;

for lexeme in Lexer::from(src) {
match lexeme.token {
Token::Comment => {
println!("comment: {:?}", lexeme.comment().unwrap());
}
Token::String => {
println!("string: {:?}", lexeme.string().unwrap());
}
_ => {}
}
}
```

This example prints the following:

```text
string: "world"
comment: "Hello world"
string: "Hello %s\n"
```

## Command-line usage

Currently command-line tool is used to test this library.
You can use it to analyze variuos C-sources and extract data.