xmladapter4sqlpredicates.java

来自「Mandarax是一个规则引擎的纯Java实现。它支持多类型的事实和基于反映的规」· Java 代码 · 共 133 行

JAVA
133
字号
package org.mandarax.xkb.framework;

/**
 *  Copyright (C) 1999-2004  Jens Dietrich (mailto:mandarax@jbdietrich.com)
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2 of the License, or (at your option) any later version.
 *
 *  This library 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
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

import java.util.Map;

import javax.sql.DataSource;

import org.jdom.Element;
import org.mandarax.kernel.LogicFactory;
import org.mandarax.sql.SQLPredicate;
import org.mandarax.sql.SQLTypeMapping;
import org.mandarax.xkb.XKBException;
/**
 * An adapter class for sql predicates. Predicates are exported with a unique id
 * that will allow other objects to share them.
 * @see org.mandarax.sql.SQLPredicate
 * @author <A href="http://www-ist.massey.ac.nz/JBDietrich" target="_top">Jens Dietrich</A>
 * @version 3.4 <7 March 05>
 * @since 1.6 
 * @deprecated from v 3.4 - support for new features such as validation will not be added to XKB, please use ZKB instead
 */

public class XMLAdapter4SQLPredicates extends CachedXMLAdapter {
      public static final String SQL_PREDICATE = "sql_predicate";
      public static final String ID = "id";
      public static final String NAME = "name";
      public static final String QUERY = "query";
      public static final String STRUCTURE = "structure";
      public static final String MAPPING = "mapping";
/**
 * Export a sql predicate, i.e., convert it to an element in the DOM.
 * @param obj an object
 * @param driver the generic driver
 * @param cache a cache used in order to associate the same
 * id with various occurences of the same object
 * @exception an XKBException is thrown if export fails
 */
protected Element _exportObject(Object obj,GenericDriver driver,Map cache) throws  XKBException {
      check(obj,SQLPredicate.class);

      SQLPredicate p = (SQLPredicate)obj;
      Element e = new Element(SQL_PREDICATE);

      // add name and query
      e.setAttribute(NAME,p.getName());
      e.setAttribute(QUERY,p.getQuery());

      // add data source
      Element ed = exportObject(p.getDataSource(),GenericDriver.DATA_SOURCE,driver,cache);
      e.addContent(ed);

      // add structure
      Element es = new Element(STRUCTURE);
      e.addContent(es);
      exportChildren(p.getStructure(),es,GenericDriver.TYPE,driver,cache);

      // add mapping (use object adapter)
      Element em = new Element(MAPPING);
      e.addContent(em);
      Element eo = exportObject(p.getTypeMapping(),GenericDriver.OBJECT,driver,cache);
      em.addContent(eo);

      return e;
}
/**
 * Build an object from an XML element.
 * @param e an element
 * @param driver the generic driver
 * @param cache a cache used to identify objects that have the same id
 * @param lfactory the logic factory used to create objects
 * @exception an XKBException is thrown if export fails
 */
protected Object _importObject(Element e,GenericDriver driver,Map cache,LogicFactory lfactory) throws XKBException {

      // get query and name
      String name = e.getAttributeValue(NAME);
      String query = e.getAttributeValue(QUERY);

      // get data source
      DataSource datasource = (DataSource)this.importChild(e,GenericDriver.DATA_SOURCE,driver,cache,lfactory);

      // get structure
      Element eStruct = e.getChild(STRUCTURE);
      Class[] structure = (Class[])importChildren(eStruct,null,driver,cache,lfactory,Class.class);

      // get type mapping
      Element eMap = e.getChild(MAPPING);
      SQLTypeMapping map = (SQLTypeMapping)importChild(eMap,GenericDriver.OBJECT,driver,cache,lfactory);

      // build SQL predicate
      SQLPredicate p = new SQLPredicate();
      p.setDataSource(datasource);
      p.setName(name);

      p.setQuery(query);
      p.setStructure(structure);

      return p;

}
/**
 * Get the name of the associated tag (element).
 * @return a string
 */
public String getTagName() {
      return SQL_PREDICATE;
}
/**
 * Get the kind of object the adapter can export/import.
 * @return a string
 */
public String getKindOfObject() {
      return GenericDriver.SQL_PREDICATE;
}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?