diff options
| author | Fuwn <[email protected]> | 2023-04-17 06:57:19 +0000 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2023-04-17 06:57:19 +0000 |
| commit | 3854c711b097b39e858d8ceabb4099a659f875a1 (patch) | |
| tree | eaeb6edb104306f17d2bbba3895ee9b93ec39036 /src/convert.rs | |
| parent | chore(README): Update examples directory path (diff) | |
| download | germ-3854c711b097b39e858d8ceabb4099a659f875a1.tar.xz germ-3854c711b097b39e858d8ceabb4099a659f875a1.zip | |
refactor: remove seldom used procedural macros
Diffstat (limited to 'src/convert.rs')
| -rw-r--r-- | src/convert.rs | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/src/convert.rs b/src/convert.rs new file mode 100644 index 0000000..22329d0 --- /dev/null +++ b/src/convert.rs @@ -0,0 +1,76 @@ +// 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 +#[derive(Clone)] +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: &(impl ToString + ?Sized), + target: &Target, +) -> String { + from_ast(&Ast::from_owned(&source.to_string()), target) +} |