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
37
38
// Copyright (c) 2017 Fabian Schuiki

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

extern crate moore_common;
extern crate rustc_serialize;

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

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


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)
	}
}