forked from M-Labs/nac3
38 lines
961 B
Rust
38 lines
961 B
Rust
|
//! This crate can be used to parse python sourcecode into a so
|
||
|
//! called AST (abstract syntax tree).
|
||
|
//!
|
||
|
//! The stages involved in this process are lexical analysis and
|
||
|
//! parsing. The lexical analysis splits the sourcecode into
|
||
|
//! tokens, and the parsing transforms those tokens into an AST.
|
||
|
//!
|
||
|
//! For example, one could do this:
|
||
|
//!
|
||
|
//! ```
|
||
|
//! use rustpython_parser::{parser, ast};
|
||
|
//!
|
||
|
//! let python_source = "print('Hello world')";
|
||
|
//! let python_ast = parser::parse_expression(python_source).unwrap();
|
||
|
//!
|
||
|
//! ```
|
||
|
|
||
|
#![doc(html_logo_url = "https://raw.githubusercontent.com/RustPython/RustPython/master/logo.png")]
|
||
|
#![doc(html_root_url = "https://docs.rs/rustpython-parser/")]
|
||
|
|
||
|
#[macro_use]
|
||
|
extern crate log;
|
||
|
use lalrpop_util::lalrpop_mod;
|
||
|
pub use rustpython_ast as ast;
|
||
|
|
||
|
pub mod error;
|
||
|
mod fstring;
|
||
|
mod function;
|
||
|
pub mod lexer;
|
||
|
pub mod mode;
|
||
|
pub mod parser;
|
||
|
lalrpop_mod!(
|
||
|
#[allow(clippy::all)]
|
||
|
#[allow(unused)]
|
||
|
python
|
||
|
);
|
||
|
pub mod token;
|