trixy 0.4.0

A rust crate used to generate multi-language apis for your application
Documentation
/*
* Copyright (C) 2023 - 2024:
* The Trinitrix Project <soispha@vhack.eu, antifallobst@systemausfall.org>
* SPDX-License-Identifier: GPL-3.0-or-later
*
* This file is part of the Trixy crate for Trinitrix.
*
* Trixy 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.
*
* This program 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
* and the GNU General Public License along with this program.
* If not, see <https://www.gnu.org/licenses/>.
*/

use error::TrixyError;

use crate::parser::lexing::TokenStream;

use self::command_spec::checked::CommandSpec;

pub mod command_spec;
pub mod error;
pub mod lexing;
pub mod parsing;

pub fn parse_trixy_lang(input: &str) -> Result<CommandSpec, Box<TrixyError>> {
    let input_tokens = TokenStream::lex(input)
        .map_err(Into::<TrixyError>::into)?
        .parse_unchecked()
        .map_err(Into::<TrixyError>::into)?
        .process(input.to_owned())
        .map_err(Into::<TrixyError>::into)?;
    Ok(input_tokens)
}