001package jmri.jmrit.logixng.actions.configurexml;
002
003import jmri.InstanceManager;
004import jmri.jmrit.logixng.DigitalActionManager;
005import jmri.jmrit.logixng.actions.Error;
006
007import org.jdom2.Element;
008
009/**
010 * Handle XML configuration for ActionLightXml objects.
011 *
012 * @author Bob Jacobsen Copyright: Copyright (c) 2004, 2008, 2010
013 * @author Daniel Bergqvist Copyright (C) 2022
014 */
015public class ErrorXml extends jmri.managers.configurexml.AbstractNamedBeanManagerConfigXML {
016
017    public ErrorXml() {
018    }
019
020    /**
021     * Default implementation for storing the contents of an Error
022     *
023     * @param o Object to store, of type Error
024     * @return Element containing the complete info
025     */
026    @Override
027    public Element store(Object o) {
028        Error p = (Error) o;
029
030        Element element = new Element("Error");
031        element.setAttribute("class", this.getClass().getName());
032        element.addContent(new Element("systemName").addContent(p.getSystemName()));
033
034        storeCommon(p, element);
035
036        element.addContent(new Element("message").addContent(p.getMessage()));
037
038        return element;
039    }
040
041    @Override
042    public boolean load(Element shared, Element perNode) {
043        String sys = getSystemName(shared);
044        String uname = getUserName(shared);
045        Error h = new Error(sys, uname);
046
047        loadCommon(h, shared);
048
049        Element elem = shared.getChild("message");  // NOI18N
050        h.setMessage((elem != null) ? elem.getValue() : "");
051
052        InstanceManager.getDefault(DigitalActionManager.class).registerAction(h);
053        return true;
054    }
055
056//    private final static org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(ErrorXml.class);
057}