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}