# 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.