/****************************************************************************** * Copyright (C) 2013 Heng Sin Low * * Copyright (C) 2013 Trek Global * * This program is free software; you can redistribute it and/or modify it * * under the terms version 2 of the GNU General Public License as published * * by the Free Software Foundation. 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, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * *****************************************************************************/ package org.adempiere.base; import java.util.logging.Level; import org.adempiere.base.equinox.EquinoxExtensionLocator; import org.adempiere.model.IShipmentProcessor; import org.compiere.util.CLogger; /** * Default {@link IShipmentProcessorFactory} implementation for core.
* Load {@link IShipmentProcessor} instance from plugin.xml (org.adempiere.model.IShipmentProcessor extension point) or class path. * @author hengsin */ public class DefaultShipmentProcessorFactory implements IShipmentProcessorFactory { private final static CLogger s_log = CLogger.getCLogger(DefaultShipmentProcessorFactory.class); /** * default constructor */ public DefaultShipmentProcessorFactory() { } @Override public IShipmentProcessor newShipmentProcessorInstance(String className) { IShipmentProcessor myProcessor = EquinoxExtensionLocator.instance().locate(IShipmentProcessor.class, className, null).getExtension(); if (myProcessor == null) { //fall back to dynamic java class loading try { Class ppClass = Class.forName(className); if (ppClass != null) myProcessor = (IShipmentProcessor) ppClass.getDeclaredConstructor().newInstance(); } catch (Error e1) { // NoClassDefFound s_log.log(Level.SEVERE, className + " - Error=" + e1.getMessage()); return null; } catch (Exception e2) { s_log.log(Level.SEVERE, className, e2); return null; } } if (myProcessor == null) { s_log.log(Level.SEVERE, "Not found in extension registry and classpath"); return null; } return myProcessor; } }