aboutsummaryrefslogtreecommitdiff
path: root/germ/src/convert.rs
diff options
context:
space:
mode:
authorFuwn <[email protected]>2022-06-28 08:03:40 +0000
committerFuwn <[email protected]>2022-06-28 08:03:40 +0000
commit50d118840448614b6309621faccc595a817782d4 (patch)
tree1ad05b1d6c0f81ff6924e0dfdac8a51b3d2f4af1 /germ/src/convert.rs
parentfix(germ): don't default macros (diff)
downloadarchived-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.rs72
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)
+}