// Copyright (C) 2019-2021 Aleo Systems Inc. // This file is part of the Leo library. // The Leo library is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // The Leo library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with the Leo library. If not, see . use leo_asg::*; use leo_errors::LeoError; use leo_parser::parse_ast; mod fail; mod pass; const TESTING_FILEPATH: &str = "input.leo"; fn load_asg(program_string: &str) -> Result, LeoError> { load_asg_imports(make_test_context(), program_string) } fn load_asg_imports<'a>(context: AsgContext<'a>, program_string: &str) -> Result, LeoError> { let ast = parse_ast(&TESTING_FILEPATH, program_string)?; Program::new(context, &ast.as_repr()) } //convenience function for tests, leaks memory pub(crate) fn make_test_context() -> AsgContext<'static> { let allocator = Box::leak(Box::new(new_alloc_context())); new_context(allocator) }