<!-- Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> $Id: RELEASE-NOTES.txt 729342 2008-12-24 17:52:36Z rahul $ Commons Digester Package Version 2.0 Release Notes INTRODUCTION ============ This is a major release. New projects are encouraged to use this release of digester. There are breaking changes from Digester 1.8, see release notes in detail before choosing to upgrade. There is no urgency for existing projects to upgrade; Digester 1.8 has proven to be a stable release. IMPORTANT NOTES ================ BREAKING CHANGES: * The minimum JDK requirement is now JDK 1.5. The provided binaries will not work on lower JDKs. The source has been updated to leverage Generics and other JDK 1.5 features where possible, and requires JDK 1.5 to compile. * This release eliminates all dependencies on Commons Collections classes. Previously, ArrayStack was used in the Digester implementation and was exposed via protected fields or inner classes of the following classes: org.apache.commons.digester.Digester, org.apache.commons.digester.CallParamRule, and org.apache.commons.digester.xmlrules.DigesterRuleParser These classes now use java.util.Stack instead. Any subclasses of the above using protected ArrayStack members will require appropriate migration to use java.util.Stack instead before they can be used with version 2.0. OTHER IMPORTANT CHANGES: * The legacy schema support has been deprecated in favor of javax.xml.validation.Schema support. DEPENDENCIES ============= Digester 2.0 users should upgrade to the recommended dependency set below where possible. The Recommended Dependency Set for Digester 2.0 is: Digester 2.0 + Logging 1.1.1 + BeanUtils 1.8.0 It is also possible to use Logging 1.0.x or BeanUtils 1.7.0 instead. NEW FEATURES ============= * XML SCHEMA SUPPORT Support for XML Schema validation using javax.xml.validation.Schema has been added to Digester. See Digester class Javadoc, and Digester#setSchema(javax.xml.validation.Schema) method. This allows usage of W3C XML Schema, Relax NG and Schematron for validation of XML documents. The legacy schema support has been deprecated (details below). * XINCLUDE AWARENESS The underlying SAXParser factory can now be easily configured to be XInclude aware. This allows for general purpose inclusion of XML or text documents, for example, and facilitates document modularity. For more details on XInclude, see: http://www.w3.org/TR/xinclude/ BUGS FROM PREVIOUS RELEASE =========================== * [DIGESTER-122] Potential NullPointerException if debug is enabled in Digester#resolveEntity() * [DIGESTER-126] Potential NullPointerException if debug is enabled in FactoryCreateRule#begin() IMPROVEMENTS OVER PREVIOUS RELEASE =================================== * [DIGESTER-111] Null arguments to all Digester#parse() methods now an IllegalArgumentException. * 'serialVersionUID' fields have been added to Serializable classes. DEPRECATIONS ============ * org.apache.commons.digester.Digester#schemaLanguage and org.apache.commons.digester.Digester#schemaLocation Use org.apache.commons.digester.Digester#schema instead. * org.apache.commons.digester.Digester#getSchemaLanguage(), org.apache.commons.digester.Digester#setSchemaLanguage(String), org.apache.commons.digester.Digester#getSchemaLocation(), and org.apache.commons.digester.Digester#setSchemaLocation(String) Use org.apache.commons.digester.Digester#getSchema() and org.apache.commons.digester.Digester#setSchema(javax.xml.validation.Schema) instead. * org.apache.commons.digester.ParserFeatureSetterFactory Switch to javax.xml.validation.Schema validation via Digester class instead. * org.apache.commons.digester.parsers package; classes org.apache.commons.digester.parsers.GenericParser and org.apache.commons.digester.parsers.XercesParser Switch to javax.xml.validation.Schema validation via Digester class instead. OTHER NOTES ============ * This is the first Digester release using Maven 2.