001/*
002 * jPOS Project [http://jpos.org]
003 * Copyright (C) 2000-2026 jPOS Software SRL
004 *
005 * This program is free software: you can redistribute it and/or modify
006 * it under the terms of the GNU Affero General Public License as
007 * published by the Free Software Foundation, either version 3 of the
008 * License, or (at your option) any later version.
009 *
010 * This program is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
013 * GNU Affero General Public License for more details.
014 *
015 * You should have received a copy of the GNU Affero General Public License
016 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
017 */
018
019package org.jpos.log.render.markdown;
020
021import org.jdom2.Element;
022import org.jdom2.output.Format;
023import org.jdom2.output.XMLOutputter;
024import org.jpos.log.LogRenderer;
025import java.io.IOException;
026import java.io.PrintStream;
027
028/** Renders a JDOM {@link Element} as Markdown-formatted log output. */
029public final class ElementMarkdownLogRenderer implements LogRenderer<Element> {
030    /** XML pretty-printer used to format element content. */
031    final XMLOutputter out = new XMLOutputter(Format.getPrettyFormat());
032
033    /** Default constructor; configures the XML outputter with Unix line separators. */
034    public ElementMarkdownLogRenderer() {
035        out.getFormat().setLineSeparator("\n");
036    }
037    @Override
038    public void render(Element o, PrintStream ps, String indent) {
039        ps.println("```xml");
040
041        try {
042            out.output(o, ps);
043        } catch (IOException ex) {
044            ex.printStackTrace(ps);
045        }
046        ps.println("```");
047    }
048    public Class<?> clazz() {
049        return Element.class;
050    }
051    public Type type() {
052        return Type.MARKDOWN;
053    }
054}