1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// Copyright (c) 2016-2021 Fabian Schuiki

//! A lexical analyzer and parser for VHDL source files as per
//! IEEE 1076-2008.

extern crate moore_common;

pub mod ast;
pub mod lexer;
pub mod parser;

use moore_common::errors::*;
use moore_common::grind::{self, Grinder};
use moore_common::source::*;

pub fn parse(src: Source) -> Result<Vec<ast::DesignUnit>, ()> {
    use self::parser::token_stream::TokenStream;

    // Get a grinder on the bytes of the source file.
    let content = src.get_content();
    let bytes = grind::from_iter(content.bytes().iter().map(|x| *x))
        .vent(|err: DiagBuilder2| eprintln!("{}", err));

    // Perform lexical analysis on the bytes.
    let tokens = lexer::Lexer::new(bytes, src);

    // Parse the file.
    let mut parser = parser::basic::BasicParser::new(tokens);
    let ast = parser::rules::parse_design_file(&mut parser);

    if parser.is_error() {
        Err(())
    } else {
        Ok(ast)
    }
}