diff --git a/src/main/org/apache/tools/ant/taskdefs/optional/extension/ExtensionAdapter.java b/src/main/org/apache/tools/ant/taskdefs/optional/extension/ExtensionAdapter.java
new file mode 100644
index 000000000..8ca28a714
--- /dev/null
+++ b/src/main/org/apache/tools/ant/taskdefs/optional/extension/ExtensionAdapter.java
@@ -0,0 +1,260 @@
+/*
+ * The Apache Software License, Version 1.1
+ *
+ * Copyright (c) 2002 The Apache Software Foundation. All rights
+ * reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ *
+ * 3. The end-user documentation included with the redistribution, if
+ * any, must include the following acknowlegement:
+ * "This product includes software developed by the
+ * Apache Software Foundation (http://www.apache.org/)."
+ * Alternately, this acknowlegement may appear in the software itself,
+ * if and wherever such third-party acknowlegements normally appear.
+ *
+ * 4. The names "The Jakarta Project", "Ant", and "Apache Software
+ * Foundation" must not be used to endorse or promote products derived
+ * from this software without prior written permission. For written
+ * permission, please contact apache@apache.org.
+ *
+ * 5. Products derived from this software may not be called "Apache"
+ * nor may "Apache" appear in their names without prior written
+ * permission of the Apache Group.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ * ====================================================================
+ *
+ * This software consists of voluntary contributions made by many
+ * individuals on behalf of the Apache Software Foundation. For more
+ * information on the Apache Software Foundation, please see
+ *
You must not set another attribute or nest elements inside + * this element if you make it a reference.
+ * + * @param reference the reference to which this instance is associated + * @exception BuildException if this instance already has been configured. + */ + public void setRefid( final Reference reference ) + throws BuildException + { + if( null != m_extensionName || + null != m_specificationVersion || + null != m_specificationVendor || + null != m_implementationVersion || + null != m_implementationVendorID || + null != m_implementationVendor || + null != m_implementationURL ) + { + throw tooManyAttributes(); + } + // change this to get the objects from the other reference + Object o = reference.getReferencedObject( getProject() ); + if( o instanceof ExtensionAdapter ) + { + final ExtensionAdapter other = (ExtensionAdapter)o; + m_extensionName = other.m_extensionName; + m_specificationVersion = other.m_specificationVersion; + m_specificationVendor = other.m_specificationVendor; + m_implementationVersion = other.m_implementationVersion; + m_implementationVendorID = other.m_implementationVendorID; + m_implementationVendor = other.m_implementationVendor; + m_implementationURL = other.m_implementationURL; + } + else + { + final String message = + reference.getRefId() + " doesn\'t refer to a Extension"; + throw new BuildException( message ); + } + + super.setRefid( reference ); + } + + /** + * Convert this adpater object into an extension object. + * + * @return the extension object + */ + Extension toExtension() + throws BuildException + { + if( null == m_extensionName ) + { + final String message = "Extension is missing name."; + throw new BuildException( message ); + } + + String specificationVersion = null; + if( null != m_specificationVersion ) + { + specificationVersion = m_specificationVersion.toString(); + } + String implementationVersion = null; + if( null != m_implementationVersion ) + { + implementationVersion = m_implementationVersion.toString(); + } + return new Extension( m_extensionName, + specificationVersion, + m_specificationVendor, + implementationVersion, + m_implementationVendorID, + m_implementationVendor, + m_implementationURL ); + } +}