33 releases

new 0.7.1 Jan 14, 2025
0.7.0-beta2 Dec 5, 2024
0.6.0-beta5 Aug 21, 2024
0.5.4 Jul 30, 2024
0.1.0 Nov 7, 2023

#553 in Development tools

Download history 18/week @ 2024-09-23 2/week @ 2024-09-30 39/week @ 2024-10-14 40/week @ 2024-11-04 3/week @ 2024-11-18 434/week @ 2024-12-02 51/week @ 2024-12-09 233/week @ 2025-01-06

236 downloads per month
Used in atlas_77

MIT license

34KB
682 lines

Atlas-core

Crate to host the Atlas77 project. An embeddable functional language.

atlas_core

atlas_core is a Rust library designed to facilitate lexical analysis and token parsing for programming languages. It provides a flexible and customizable lexer implementation, along with macros to define language-specific tokens, keywords, and symbols. Features

  • Lexer Generation: Automatically generate lexer structures and methods using macros.
  • Token Kind Definition: Easily define various token kinds including literals, keywords, and symbols.
  • Error Handling: Robust error handling with detailed error messages and support for recoverable errors.
  • Customizable: Configure your lexer with specific keywords, symbols, and number parsing options.

Installation

Add the following to your Cargo.toml:


[dependencies]
atlas_core = "0.6.0"

Usage

Defining Symbols

Everything is under refactoring, so it won't work like that. Stay tuned for update!

Use the symbols! macro to define symbols used in your language:


symbols! {
    '+' => Plus,
    '-' => Minus,
    '*' => Asterisk,
    '/' => Slash,
    // Add more symbols as needed
}

Defining Keywords

Use the keyword! macro to define keywords:


keyword! {
    "if",
    "else",
    "while",
    // Add more keywords as needed
}

Configuring Number Parsing

Use the number! macro to configure number parsing options:


number! {
    enable_f64: true,
    enable_i64: true
}

Generating the Lexer

Use the lexer! macro to generate the lexer with default or customized configurations:


lexer!();

Example

Here's an example of using atlas_core to create a simple lexer:


use atlas_core::prelude::*;

symbols! {
    '+' => Plus,
    '{' => LBracket,
    '}' => RBracket,
    ';' => SemiColon,
}

keyword! {
    "if",
    "return"
}

number! {
    enable_f64: true,
    enable_i64: true
}

lexer!();

fn main() {
    let source = "if x + y { return 42; }";
    let tokens = Lexer::tokenize("example.rs", source).unwrap();
    
    for token in tokens {
        println!("{:?}", token);
    }
}

Contributing

Contributions are welcome! Please open an issue or submit a pull request.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Dependencies

~0.3–1MB
~21K SLoC