diff options
| author | Fuwn <[email protected]> | 2022-06-28 08:03:40 +0000 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2022-06-28 08:03:40 +0000 |
| commit | 50d118840448614b6309621faccc595a817782d4 (patch) | |
| tree | 1ad05b1d6c0f81ff6924e0dfdac8a51b3d2f4af1 /germ/src/convert.rs | |
| parent | fix(germ): don't default macros (diff) | |
| download | archived-germ-0.3.3.tar.xz archived-germ-0.3.3.zip | |
fix(crate): crate locations for readmev0.3.3
Diffstat (limited to 'germ/src/convert.rs')
| -rw-r--r-- | germ/src/convert.rs | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/germ/src/convert.rs b/germ/src/convert.rs new file mode 100644 index 0000000..2e323e1 --- /dev/null +++ b/germ/src/convert.rs @@ -0,0 +1,72 @@ +// This file is part of Germ <https://github.com/gemrest/germ>. +// Copyright (C) 2022-2022 Fuwn <[email protected]> +// +// 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 <http://www.gnu.org/licenses/>. +// +// Copyright (C) 2022-2022 Fuwn <[email protected]> +// SPDX-License-Identifier: GPL-3.0-only + +//! Convert Gemtext into many types of markup. + +use crate::ast::Ast; + +mod html; +mod markdown; + +#[cfg(feature = "macros")] +mod macros; + +/// 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; +/// +/// let _ = convert::from_ast( +/// &germ::ast::Ast::from_string(r#"=> gemini://gem.rest/ GemRest"#), +/// &convert::Target::HTML, +/// ); +/// ``` +#[must_use] +pub fn from_ast(source: &Ast, target: &Target) -> String { + match target { + Target::Markdown => markdown::convert(source.inner()), + Target::HTML => html::convert(source.inner()), + } +} + +/// Convert raw Gemtext into an alternative markup format. +/// +/// # Example +/// +/// ```rust +/// use germ::convert; +/// +/// let _ = convert::from_string( +/// r#"=> gemini://gem.rest/ GemRest"#, +/// &convert::Target::HTML, +/// ); +/// ``` +#[must_use] +pub fn from_string(source: &str, target: &Target) -> String { + from_ast(&Ast::from_string(source), target) +} |