// This file is part of Germ . // Copyright (C) 2022-2022 Fuwn // // This program 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, version 3. // // 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 // along with this program. If not, see . // // Copyright (C) 2022-2022 Fuwn // SPDX-License-Identifier: GPL-3.0-only //! Convert Gemtext into many types of markup. mod html; mod markdown; /// Different targets to convert Gemtext to pub enum Target { /// Convert Gemtext to HTML HTML, /// Convert Gemtext to Markdown Markdown, } /// Convert AST'd Gemtext into an alternative markup format. /// /// # Example /// /// ```rust /// use germ::convert; /// /// convert::from_ast( /// germ::ast::build(r#"=> gemini://gem.rest/ GemRest"#), /// &convert::Target::HTML, /// ); /// ``` #[must_use] pub fn from_ast(source: Vec, target: &Target) -> String { match target { Target::Markdown => markdown::convert(source), Target::HTML => html::convert(source), } } /// Convert raw Gemtext into an alternative markup format. /// /// # Example /// /// ```rust /// use germ::convert; /// /// convert::from_string( /// r#"=> gemini://gem.rest/ GemRest"#, /// &convert::Target::HTML, /// ); /// ``` #[must_use] pub fn from_string(source: &str, target: &Target) -> String { from_ast(crate::ast::build(source), target) }