2 releases
0.2.1 | Jun 20, 2024 |
---|---|
0.2.0 | Jun 20, 2024 |
#1549 in Parser implementations
40KB
117 lines
Sponge
Sponge is a powerful Rust module designed to convert Rust code into assembly language (ASM). It tokenizes Rust code, parses the tokens, and generates corresponding assembly code, making it easier to understand and optimize your Rust programs at the assembly level.
Description
Sponge aims to bridge the gap between high-level Rust code and low-level assembly code. By converting Rust code into ASM, developers can gain insights into how their Rust code translates into machine instructions, which is valuable for performance optimization and learning purposes.
Features
- Tokenization: Breaks down Rust code into tokens.
- Parsing: Converts tokens into a structured format.
- ASM Generation: Produces equivalent assembly code from parsed tokens.
- Customizable Output: Allows for tailored assembly code generation based on specific needs.
Installation
Add the following to your Cargo.toml
:
[dependencies]
sponge = "0.2.0"
Run cargo build
to install the dependencies.
Usage
Sponge can be used in multiple ways to suit your needs. You can use it to tokenize Rust code, parse the tokens, or generate ASM code.
Tokenizing Rust Code
To tokenize a Rust file:
extern crate sponge;
use sponge::decompose_tokens::decompose;
fn main() {
let filename = "script.rs";
match decompose(filename) {
Ok(tokens) => println!("{:?}", tokens),
Err(e) => eprintln!("Error: {}", e),
}
}
Parsing Tokens
To parse the tokens into a structured format:
extern crate sponge;
use sponge::decompose_tokens::decompose;
use sponge::parse_tokens::parse;
fn main() {
let filename = "script.rs";
match decompose(filename) {
Ok(tokens) => {
let parsed_tokens = parse(tokens);
println!("{:?}", parsed_tokens);
},
Err(e) => eprintln!("Error: {}", e),
}
}
Generating ASM Code
To generate ASM code from parsed tokens:
extern crate sponge;
use sponge::decompose_tokens::decompose;
use sponge::parse_tokens::parse;
use sponge::generate_asm::generate;
fn main() {
let filename = "script.rs";
match decompose(filename) {
Ok(tokens) => {
let parsed_tokens = parse(tokens);
let asm_code = generate(&parsed_tokens);
println!("{}", asm_code);
},
Err(e) => eprintln!("Error: {}", e),
}
}
Using the Command Line Interface
Sponge also provides a simple CLI to facilitate the conversion process. The available options are:
-i, --input <FILE>
: Specifies the input Rust file.-o, --output <FILE>
: Specifies the output ASM file.
Example
-
Create a Rust file (
script.rs
) with the following content:fn main() { let REG_1: i32 = 50; }
-
Run the following command in your terminal to generate the ASM code:
sponge -i script.rs -o script.asm
This will produce the
script.asm
file:section .data section .bss section .text global _start _start: mov r1, 50 ; Move the value 50 into register 1 ; Exit the program mov rax, 60 ; System call for exit xor rdi, rdi ; Exit code 0 syscall ; Invoke the system call
Contributing
We welcome contributions to Sponge! Here’s how you can help:
- Fork the repository.
- Create a new branch (
git checkout -b feature-branch
). - Commit your changes (
git commit -am "Add new feature"
). - Push to the branch (
git push origin feature-branch
). - Create a new Pull Request.
Please ensure your code follows the project’s coding standards and includes appropriate tests.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contact
For any inquiries or issues, please contact Bradinator at [email protected].
Acknowledgements
Special thanks to all contributors and the Rust community for their support and contributions.
Dependencies
~1.5–2.6MB
~49K SLoC