OSGi R4 Core updates:
o  Added package, about, license docs
o  Updated pom to package as bundle
o  Removed util tracker package

git-svn-id: https://svn.apache.org/repos/asf/incubator/felix/trunk@390223 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/org.osgi/pom.xml b/org.osgi/pom.xml
index fd7b494..dfe1236 100644
--- a/org.osgi/pom.xml
+++ b/org.osgi/pom.xml
@@ -5,7 +5,31 @@
     <version>0.8.0-SNAPSHOT</version>
   </parent>
   <modelVersion>4.0.0</modelVersion>
-  <packaging>jar</packaging>
-  <name>OSGi Framework API</name>
-  <artifactId>org.osgi</artifactId>
+  <name>OSGi R4 Core Bundle</name>
+  <artifactId>org.osgi.core</artifactId>
+  <packaging>osgi-bundle</packaging>
+  <build>
+    <plugins>
+      <plugin>
+        <groupId>org.apache.felix.plugins</groupId>
+        <artifactId>maven-osgi-plugin</artifactId>
+        <version>${pom.version}</version>
+        <extensions>true</extensions>
+        <configuration>
+          <osgiManifest>
+            <bundleName>osgi.core</bundleName>
+            <bundleVendor>OSGi Alliance</bundleVendor>
+            <!--<bundleVersion>4</bundleVersion>-->
+            <bundleSymbolicName>osgi.core</bundleSymbolicName>
+            <bundleDescription>OSGi Service Platform Release 4 Core Interfaces and Classes.</bundleDescription>
+            <!--<bundleCopyright>Copyright (c) OSGi Alliance (2000, 2005). All Rights Reserved.</bundleCopyright>-->
+            <bundleCategory>osgi</bundleCategory>
+            <!--<bundleDocUrl>http://www.osgi.org/</bundleDocUrl>-->
+            <exportPackage>org.osgi.framework; specification-version="1.3", org.osgi.service.condpermadmin; specification-version="1.0", org.osgi.service.packageadmin; specification-version="1.2", org.osgi.service.permissionadmin; specification-version="1.2", org.osgi.service.startlevel; specification-version="1.0", org.osgi.service.url; specification-version="1.0"</exportPackage>
+            <!--<dynamicImportPackage>*</dynamicImportPackage>-->
+          </osgiManifest>
+        </configuration>
+      </plugin>
+    </plugins>
+  </build>
 </project>
diff --git a/org.osgi/src/main/java/org/osgi/framework/package.html b/org.osgi/src/main/java/org/osgi/framework/package.html
new file mode 100644
index 0000000..c53ddc3
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/framework/package.html
@@ -0,0 +1,11 @@
+<!-- $Header: /cvshome/build/org.osgi.framework/src/org/osgi/framework/package.html,v 1.2 2004/12/01 19:01:49 hargrave Exp $ -->
+<BODY>
+<p>The OSGi Framework Package. Specification Version 1.3.
+<p>Bundles wishing to use this package must list the package
+in the Import-Package header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.framework;version=1.3
+</pre>
+</BODY>
+
diff --git a/org.osgi/src/main/java/org/osgi/service/condpermadmin/package.html b/org.osgi/src/main/java/org/osgi/service/condpermadmin/package.html
new file mode 100644
index 0000000..c0f1ef4
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/service/condpermadmin/package.html
@@ -0,0 +1,10 @@
+<!-- $Header: /cvshome/build/org.osgi.service.condpermadmin/src/org/osgi/service/condpermadmin/package.html,v 1.5 2005/08/05 01:35:14 hargrave Exp $ -->
+<BODY>
+<P>The OSGi Conditional Permission Admin Specification Version 1.0.
+<p>Bundles wishing to use this package must list the package
+in the <TT>Import-Package</TT> header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.service.condpermadmin; version=1.0
+</pre>
+</BODY>
diff --git a/org.osgi/src/main/java/org/osgi/service/packageadmin/package.html b/org.osgi/src/main/java/org/osgi/service/packageadmin/package.html
new file mode 100644
index 0000000..0a08c22
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/service/packageadmin/package.html
@@ -0,0 +1,11 @@
+<!-- $Header: /cvshome/build/org.osgi.service.packageadmin/src/org/osgi/service/packageadmin/package.html,v 1.2 2004/12/01 19:01:45 hargrave Exp $ -->
+<BODY>
+<P>The OSGi Package Admin service Package. Specification Version 1.2.
+<p>Bundles wishing to use this package must list the package
+in the Import-Package header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.service.packageadmin; version=1.2
+</pre>
+</BODY>
+
diff --git a/org.osgi/src/main/java/org/osgi/service/permissionadmin/package.html b/org.osgi/src/main/java/org/osgi/service/permissionadmin/package.html
new file mode 100644
index 0000000..b6a9249
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/service/permissionadmin/package.html
@@ -0,0 +1,11 @@
+<!-- $Header: /cvshome/build/org.osgi.service.permissionadmin/src/org/osgi/service/permissionadmin/package.html,v 1.3 2005/08/04 03:34:57 hargrave Exp $ -->
+<BODY>
+<P>The OSGi Permission Admin service Package. Specification Version 1.2.
+<p>Bundles wishing to use this package must list the package
+in the Import-Package header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.service.permissionadmin; version=1.2
+</pre>
+</BODY>
+
diff --git a/org.osgi/src/main/java/org/osgi/service/startlevel/package.html b/org.osgi/src/main/java/org/osgi/service/startlevel/package.html
new file mode 100644
index 0000000..db82c8e
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/service/startlevel/package.html
@@ -0,0 +1,11 @@
+<!-- $Header: /cvshome/build/org.osgi.service.startlevel/src/org/osgi/service/startlevel/package.html,v 1.2 2004/12/01 19:01:29 hargrave Exp $ -->
+<BODY>
+<P>The OSGi StartLevel service Package. Specification Version 1.0.
+<p>Bundles wishing to use this package must list the package
+in the Import-Package header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.service.startlevel; version=1.0
+</pre>
+</BODY>
+
diff --git a/org.osgi/src/main/java/org/osgi/service/url/package.html b/org.osgi/src/main/java/org/osgi/service/url/package.html
new file mode 100644
index 0000000..f182a0b
--- /dev/null
+++ b/org.osgi/src/main/java/org/osgi/service/url/package.html
@@ -0,0 +1,10 @@
+<!-- $Header: /cvshome/build/org.osgi.service.url/src/org/osgi/service/url/package.html,v 1.2 2004/12/01 19:01:44 hargrave Exp $ -->
+<BODY>
+<P>The OSGi URL Stream and Content Handlers API Package. Specification Version 1.0.
+<p>Bundles wishing to use this package must list the package
+in the Import-Package header of the bundle's manifest.
+For example:
+<pre>
+Import-Package: org.osgi.service.url; version=1.0
+</pre>
+</BODY>
diff --git a/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTracker.java b/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTracker.java
deleted file mode 100644
index 816374f..0000000
--- a/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTracker.java
+++ /dev/null
@@ -1,1139 +0,0 @@
-/*

- * $Header: /cvshome/build/org.osgi.util.tracker/src/org/osgi/util/tracker/ServiceTracker.java,v 1.18 2006/03/14 01:20:01 hargrave Exp $

- * 

- * Copyright (c) OSGi Alliance (2000, 2005). All Rights Reserved.

- * 

- * Licensed 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.

- */

-

-package org.osgi.util.tracker;

-

-import java.util.*;

-

-import org.osgi.framework.*;

-

-/**

- * The <code>ServiceTracker</code> class simplifies using services from the

- * Framework's service registry.

- * <p>

- * A <code>ServiceTracker</code> object is constructed with search criteria

- * and a <code>ServiceTrackerCustomizer</code> object. A

- * <code>ServiceTracker</code> object can use the

- * <code>ServiceTrackerCustomizer</code> object to customize the service

- * objects to be tracked. The <code>ServiceTracker</code> object can then be

- * opened to begin tracking all services in the Framework's service registry

- * that match the specified search criteria. The <code>ServiceTracker</code>

- * object correctly handles all of the details of listening to

- * <code>ServiceEvent</code> objects and getting and ungetting services.

- * <p>

- * The <code>getServiceReferences</code> method can be called to get

- * references to the services being tracked. The <code>getService</code> and

- * <code>getServices</code> methods can be called to get the service objects

- * for the tracked service.

- * 

- * @version $Revision: 1.18 $

- */

-public class ServiceTracker implements ServiceTrackerCustomizer {

-	/* set this to true to compile in debug messages */

-	static final boolean				DEBUG			= false;

-	/**

-	 * Bundle context this <code>ServiceTracker</code> object is tracking

-	 * against.

-	 */

-	protected final BundleContext		context;

-	/**

-	 * Filter specifying search criteria for the services to track.

-	 * 

-	 * @since 1.1

-	 */

-	protected final Filter				filter;

-	/**

-	 * <code>ServiceTrackerCustomizer</code> object for this tracker.

-	 */

-	final ServiceTrackerCustomizer		customizer;

-	/**

-	 * Filter string for use when adding the ServiceListener. If this field is

-	 * set, then certain optimizations can be taken since we don't have a user

-	 * supplied filter.

-	 */

-	final String						listenerFilter;

-	/**

-	 * Class name to be tracked. If this field is set, then we are tracking by

-	 * class name.

-	 */

-	private final String				trackClass;

-	/**

-	 * Reference to be tracked. If this field is set, then we are tracking a

-	 * single ServiceReference.

-	 */

-	private final ServiceReference		trackReference;

-	/**

-	 * Tracked services: <code>ServiceReference</code> object -> customized

-	 * Object and <code>ServiceListener</code> object

-	 */

-	private Tracked						tracked;

-	/**

-	 * Modification count. This field is initialized to zero by open, set to -1

-	 * by close and incremented by modified.

-	 * 

-	 * This field is volatile since it is accessed by multiple threads.

-	 */

-	private volatile int				trackingCount	= -1;

-	/**

-	 * Cached ServiceReference for getServiceReference.

-	 * 

-	 * This field is volatile since it is accessed by multiple threads.

-	 */

-	private volatile ServiceReference	cachedReference;

-	/**

-	 * Cached service object for getService.

-	 * 

-	 * This field is volatile since it is accessed by multiple threads.

-	 */

-	private volatile Object				cachedService;

-

-	/**

-	 * Create a <code>ServiceTracker</code> object on the specified

-	 * <code>ServiceReference</code> object.

-	 * 

-	 * <p>

-	 * The service referenced by the specified <code>ServiceReference</code>

-	 * object will be tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * @param context <code>BundleContext</code> object against which the

-	 *        tracking is done.

-	 * @param reference <code>ServiceReference</code> object for the service

-	 *        to be tracked.

-	 * @param customizer The customizer object to call when services are added,

-	 *        modified, or removed in this <code>ServiceTracker</code> object.

-	 *        If customizer is <code>null</code>, then this

-	 *        <code>ServiceTracker</code> object will be used as the

-	 *        <code>ServiceTrackerCustomizer</code> object and the

-	 *        <code>ServiceTracker</code> object will call the

-	 *        <code>ServiceTrackerCustomizer</code> methods on itself.

-	 */

-	public ServiceTracker(BundleContext context, ServiceReference reference,

-			ServiceTrackerCustomizer customizer) {

-		this.context = context;

-		this.trackReference = reference;

-		this.trackClass = null;

-		this.customizer = (customizer == null) ? this : customizer;

-		this.listenerFilter = "(" + Constants.SERVICE_ID + "=" + reference.getProperty(Constants.SERVICE_ID).toString() + ")"; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$

-		try {

-			this.filter = context.createFilter(listenerFilter);

-		}

-		catch (InvalidSyntaxException e) { // we could only get this exception

-			// if the ServiceReference was

-			// invalid

-			throw new IllegalArgumentException(

-					"unexpected InvalidSyntaxException: " + e.getMessage()); //$NON-NLS-1$

-		}

-	}

-

-	/**

-	 * Create a <code>ServiceTracker</code> object on the specified class

-	 * name.

-	 * 

-	 * <p>

-	 * Services registered under the specified class name will be tracked by

-	 * this <code>ServiceTracker</code> object.

-	 * 

-	 * @param context <code>BundleContext</code> object against which the

-	 *        tracking is done.

-	 * @param clazz Class name of the services to be tracked.

-	 * @param customizer The customizer object to call when services are added,

-	 *        modified, or removed in this <code>ServiceTracker</code> object.

-	 *        If customizer is <code>null</code>, then this

-	 *        <code>ServiceTracker</code> object will be used as the

-	 *        <code>ServiceTrackerCustomizer</code> object and the

-	 *        <code>ServiceTracker</code> object will call the

-	 *        <code>ServiceTrackerCustomizer</code> methods on itself.

-	 */

-	public ServiceTracker(BundleContext context, String clazz,

-			ServiceTrackerCustomizer customizer) {

-		this.context = context;

-		this.trackReference = null;

-		this.trackClass = clazz;

-		this.customizer = (customizer == null) ? this : customizer;

-		this.listenerFilter = "(" + Constants.OBJECTCLASS + "=" + clazz.toString() + ")"; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$

-		try {

-			this.filter = context.createFilter(listenerFilter);

-		}

-		catch (InvalidSyntaxException e) { // we could only get this exception

-			// if the clazz argument was

-			// malformed

-			throw new IllegalArgumentException(

-					"unexpected InvalidSyntaxException: " + e.getMessage()); //$NON-NLS-1$

-		}

-	}

-

-	/**

-	 * Create a <code>ServiceTracker</code> object on the specified

-	 * <code>Filter</code> object.

-	 * 

-	 * <p>

-	 * Services which match the specified <code>Filter</code> object will be

-	 * tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * @param context <code>BundleContext</code> object against which the

-	 *        tracking is done.

-	 * @param filter <code>Filter</code> object to select the services to be

-	 *        tracked.

-	 * @param customizer The customizer object to call when services are added,

-	 *        modified, or removed in this <code>ServiceTracker</code> object.

-	 *        If customizer is null, then this <code>ServiceTracker</code>

-	 *        object will be used as the <code>ServiceTrackerCustomizer</code>

-	 *        object and the <code>ServiceTracker</code> object will call the

-	 *        <code>ServiceTrackerCustomizer</code> methods on itself.

-	 * @since 1.1

-	 */

-	public ServiceTracker(BundleContext context, Filter filter,

-			ServiceTrackerCustomizer customizer) {

-		this.context = context;

-		this.trackReference = null;

-		this.trackClass = null;

-		this.listenerFilter = null;

-		this.filter = filter;

-		this.customizer = (customizer == null) ? this : customizer;

-		if ((context == null) || (filter == null)) { // we throw a NPE here

-			// to

-			// be consistent with the

-			// other constructors

-			throw new NullPointerException();

-		}

-	}

-

-	/**

-	 * Open this <code>ServiceTracker</code> object and begin tracking

-	 * services.

-	 * 

-	 * <p>

-	 * This method calls <code>open(false)</code>.

-	 * 

-	 * @throws java.lang.IllegalStateException if the <code>BundleContext</code>

-	 *         object with which this <code>ServiceTracker</code> object was

-	 *         created is no longer valid.

-	 * @see #open(boolean)

-	 */

-	public void open() {

-		open(false);

-	}

-

-	/**

-	 * Open this <code>ServiceTracker</code> object and begin tracking

-	 * services.

-	 * 

-	 * <p>

-	 * Services which match the search criteria specified when this

-	 * <code>ServiceTracker</code> object was created are now tracked by this

-	 * <code>ServiceTracker</code> object.

-	 * 

-	 * @param trackAllServices If <code>true</code>, then this

-	 *        <code>ServiceTracker</code> will track all matching services

-	 *        regardless of class loader accessibility. If <code>false</code>,

-	 *        then this <code>ServiceTracker</code> will only track matching

-	 *        services which are class loader accessibile to the bundle whose

-	 *        <code>BundleContext</code> is used by this

-	 *        <code>ServiceTracker</code>.

-	 * @throws java.lang.IllegalStateException if the <code>BundleContext</code>

-	 *         object with which this <code>ServiceTracker</code> object was

-	 *         created is no longer valid.

-	 * @since 1.3

-	 */

-	public synchronized void open(boolean trackAllServices) {

-		if (tracked != null) {

-			return;

-		}

-		if (DEBUG) {

-			System.out.println("ServiceTracker.open: " + filter); //$NON-NLS-1$

-		}

-		tracked = trackAllServices ? new AllTracked() : new Tracked();

-		trackingCount = 0;

-		synchronized (tracked) {

-			try {

-				context.addServiceListener(tracked, listenerFilter);

-				ServiceReference[] references;

-				if (listenerFilter == null) { // user supplied filter

-					references = getInitialReferences(trackAllServices, null,

-							filter.toString());

-				}

-				else { // constructor supplied filter

-					if (trackClass == null) {

-						references = new ServiceReference[] {trackReference};

-					}

-					else {

-						references = getInitialReferences(trackAllServices,

-								trackClass, null);

-					}

-				}

-

-				tracked.setInitialServices(references); // set tracked with

-				// the initial

-				// references

-			}

-			catch (InvalidSyntaxException e) {

-				throw new RuntimeException(

-						"unexpected InvalidSyntaxException: " + e.getMessage()); //$NON-NLS-1$

-			}

-		}

-		/* Call tracked outside of synchronized region */

-		tracked.trackInitialServices(); // process the initial references

-	}

-

-	/**

-	 * Returns the list of initial <code>ServiceReference</code> objects that

-	 * will be tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * @param trackAllServices If true, use getAllServiceReferences.

-	 * @param trackClass the class name with which the service was registered,

-	 *        or null for all services.

-	 * @param filterString the filter criteria or null for all services.

-	 * @return the list of initial <code>ServiceReference</code> objects.

-	 * @throws InvalidSyntaxException if the filter uses an invalid syntax.

-	 */

-	private ServiceReference[] getInitialReferences(boolean trackAllServices,

-			String trackClass, String filterString)

-			throws InvalidSyntaxException {

-		if (trackAllServices) {

-			return context.getAllServiceReferences(trackClass, filterString);

-		}

-		else {

-			return context.getServiceReferences(trackClass, filterString);

-		}

-	}

-

-	/**

-	 * Close this <code>ServiceTracker</code> object.

-	 * 

-	 * <p>

-	 * This method should be called when this <code>ServiceTracker</code>

-	 * object should end the tracking of services.

-	 */

-	public synchronized void close() {

-		if (tracked == null) {

-			return;

-		}

-		if (DEBUG) {

-			System.out.println("ServiceTracker.close: " + filter); //$NON-NLS-1$

-		}

-		tracked.close();

-		ServiceReference[] references = getServiceReferences();

-		Tracked outgoing = tracked;

-		tracked = null;

-		try {

-			context.removeServiceListener(outgoing);

-		}

-		catch (IllegalStateException e) {

-			/* In case the context was stopped. */

-		}

-		if (references != null) {

-			for (int i = 0; i < references.length; i++) {

-				outgoing.untrack(references[i]);

-			}

-		}

-		trackingCount = -1;

-		if (DEBUG) {

-			if ((cachedReference == null) && (cachedService == null)) {

-				System.out

-						.println("ServiceTracker.close[cached cleared]: " + filter); //$NON-NLS-1$

-			}

-		}

-	}

-

-	/**

-	 * Default implementation of the

-	 * <code>ServiceTrackerCustomizer.addingService</code> method.

-	 * 

-	 * <p>

-	 * This method is only called when this <code>ServiceTracker</code> object

-	 * has been constructed with a <code>null ServiceTrackerCustomizer</code>

-	 * argument.

-	 * 

-	 * The default implementation returns the result of calling

-	 * <code>getService</code>, on the <code>BundleContext</code> object

-	 * with which this <code>ServiceTracker</code> object was created, passing

-	 * the specified <code>ServiceReference</code> object.

-	 * <p>

-	 * This method can be overridden in a subclass to customize the service

-	 * object to be tracked for the service being added. In that case, take care

-	 * not to rely on the default implementation of removedService that will

-	 * unget the service.

-	 * 

-	 * @param reference Reference to service being added to this

-	 *        <code>ServiceTracker</code> object.

-	 * @return The service object to be tracked for the service added to this

-	 *         <code>ServiceTracker</code> object.

-	 * @see ServiceTrackerCustomizer

-	 */

-	public Object addingService(ServiceReference reference) {

-		return context.getService(reference);

-	}

-

-	/**

-	 * Default implementation of the

-	 * <code>ServiceTrackerCustomizer.modifiedService</code> method.

-	 * 

-	 * <p>

-	 * This method is only called when this <code>ServiceTracker</code> object

-	 * has been constructed with a <code>null ServiceTrackerCustomizer</code>

-	 * argument.

-	 * 

-	 * The default implementation does nothing.

-	 * 

-	 * @param reference Reference to modified service.

-	 * @param service The service object for the modified service.

-	 * @see ServiceTrackerCustomizer

-	 */

-	public void modifiedService(ServiceReference reference, Object service) {

-	}

-

-	/**

-	 * Default implementation of the

-	 * <code>ServiceTrackerCustomizer.removedService</code> method.

-	 * 

-	 * <p>

-	 * This method is only called when this <code>ServiceTracker</code> object

-	 * has been constructed with a <code>null ServiceTrackerCustomizer</code>

-	 * argument.

-	 * 

-	 * The default implementation calls <code>ungetService</code>, on the

-	 * <code>BundleContext</code> object with which this

-	 * <code>ServiceTracker</code> object was created, passing the specified

-	 * <code>ServiceReference</code> object.

-	 * <p>

-	 * This method can be overridden in a subclass. If the default

-	 * implementation of <code>addingService</code> method was used, this

-	 * method must unget the service.

-	 * 

-	 * @param reference Reference to removed service.

-	 * @param service The service object for the removed service.

-	 * @see ServiceTrackerCustomizer

-	 */

-	public void removedService(ServiceReference reference, Object service) {

-		context.ungetService(reference);

-	}

-

-	/**

-	 * Wait for at least one service to be tracked by this

-	 * <code>ServiceTracker</code> object.

-	 * <p>

-	 * It is strongly recommended that <code>waitForService</code> is not used

-	 * during the calling of the <code>BundleActivator</code> methods.

-	 * <code>BundleActivator</code> methods are expected to complete in a

-	 * short period of time.

-	 * 

-	 * @param timeout time interval in milliseconds to wait. If zero, the method

-	 *        will wait indefinately.

-	 * @return Returns the result of <code>getService()</code>.

-	 * @throws InterruptedException If another thread has interrupted the

-	 *         current thread.

-	 * @throws IllegalArgumentException If the value of timeout is negative.

-	 */

-	public Object waitForService(long timeout) throws InterruptedException {

-		if (timeout < 0) {

-			throw new IllegalArgumentException("timeout value is negative"); //$NON-NLS-1$

-		}

-		Object object = getService();

-		while (object == null) {

-			Tracked tracked = this.tracked; /*

-											 * use local var since we are not

-											 * synchronized

-											 */

-			if (tracked == null) { /* if ServiceTracker is not open */

-				return null;

-			}

-			synchronized (tracked) {

-				if (tracked.size() == 0) {

-					tracked.wait(timeout);

-				}

-			}

-			object = getService();

-			if (timeout > 0) {

-				return object;

-			}

-		}

-		return object;

-	}

-

-	/**

-	 * Return an array of <code>ServiceReference</code> objects for all

-	 * services being tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * @return Array of <code>ServiceReference</code> objects or

-	 *         <code>null</code> if no service are being tracked.

-	 */

-	public ServiceReference[] getServiceReferences() {

-		Tracked tracked = this.tracked; /*

-										 * use local var since we are not

-										 * synchronized

-										 */

-		if (tracked == null) { /* if ServiceTracker is not open */

-			return null;

-		}

-		synchronized (tracked) {

-			int length = tracked.size();

-			if (length == 0) {

-				return null;

-			}

-			ServiceReference[] references = new ServiceReference[length];

-			Enumeration keys = tracked.keys();

-			for (int i = 0; i < length; i++) {

-				references[i] = (ServiceReference) keys.nextElement();

-			}

-			return references;

-		}

-	}

-

-	/**

-	 * Returns a <code>ServiceReference</code> object for one of the services

-	 * being tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * <p>

-	 * If multiple services are being tracked, the service with the highest

-	 * ranking (as specified in its <code>service.ranking</code> property) is

-	 * returned.

-	 * 

-	 * <p>

-	 * If there is a tie in ranking, the service with the lowest service ID (as

-	 * specified in its <code>service.id</code> property); that is, the

-	 * service that was registered first is returned.

-	 * <p>

-	 * This is the same algorithm used by

-	 * <code>BundleContext.getServiceReference</code>.

-	 * 

-	 * @return <code>ServiceReference</code> object or <code>null</code> if

-	 *         no service is being tracked.

-	 * @since 1.1

-	 */

-	public ServiceReference getServiceReference() {

-		ServiceReference reference = cachedReference;

-		if (reference != null) {

-			if (DEBUG) {

-				System.out

-						.println("ServiceTracker.getServiceReference[cached]: " + filter); //$NON-NLS-1$

-			}

-			return reference;

-		}

-		if (DEBUG) {

-			System.out.println("ServiceTracker.getServiceReference: " + filter); //$NON-NLS-1$

-		}

-		ServiceReference[] references = getServiceReferences();

-		int length = (references == null) ? 0 : references.length;

-		if (length == 0) /* if no service is being tracked */

-		{

-			return null;

-		}

-		int index = 0;

-		if (length > 1) /* if more than one service, select highest ranking */

-		{

-			int rankings[] = new int[length];

-			int count = 0;

-			int maxRanking = Integer.MIN_VALUE;

-			for (int i = 0; i < length; i++) {

-				Object property = references[i]

-						.getProperty(Constants.SERVICE_RANKING);

-				int ranking = (property instanceof Integer) ? ((Integer) property)

-						.intValue()

-						: 0;

-				rankings[i] = ranking;

-				if (ranking > maxRanking) {

-					index = i;

-					maxRanking = ranking;

-					count = 1;

-				}

-				else {

-					if (ranking == maxRanking) {

-						count++;

-					}

-				}

-			}

-			if (count > 1) /* if still more than one service, select lowest id */

-			{

-				long minId = Long.MAX_VALUE;

-				for (int i = 0; i < length; i++) {

-					if (rankings[i] == maxRanking) {

-						long id = ((Long) (references[i]

-								.getProperty(Constants.SERVICE_ID)))

-								.longValue();

-						if (id < minId) {

-							index = i;

-							minId = id;

-						}

-					}

-				}

-			}

-		}

-		return cachedReference = references[index];

-	}

-

-	/**

-	 * Returns the service object for the specified

-	 * <code>ServiceReference</code> object if the referenced service is being

-	 * tracked by this <code>ServiceTracker</code> object.

-	 * 

-	 * @param reference Reference to the desired service.

-	 * @return Service object or <code>null</code> if the service referenced

-	 *         by the specified <code>ServiceReference</code> object is not

-	 *         being tracked.

-	 */

-	public Object getService(ServiceReference reference) {

-		Tracked tracked = this.tracked; /*

-										 * use local var since we are not

-										 * synchronized

-										 */

-		if (tracked == null) { /* if ServiceTracker is not open */

-			return null;

-		}

-		synchronized (tracked) {

-			return tracked.get(reference);

-		}

-	}

-

-	/**

-	 * Return an array of service objects for all services being tracked by this

-	 * <code>ServiceTracker</code> object.

-	 * 

-	 * @return Array of service objects or <code>null</code> if no service are

-	 *         being tracked.

-	 */

-	public Object[] getServices() {

-		Tracked tracked = this.tracked; /*

-										 * use local var since we are not

-										 * synchronized

-										 */

-		if (tracked == null) { /* if ServiceTracker is not open */

-			return null;

-		}

-		synchronized (tracked) {

-			ServiceReference[] references = getServiceReferences();

-			int length = (references == null) ? 0 : references.length;

-			if (length == 0) {

-				return null;

-			}

-			Object[] objects = new Object[length];

-			for (int i = 0; i < length; i++) {

-				objects[i] = getService(references[i]);

-			}

-			return objects;

-		}

-	}

-

-	/**

-	 * Returns a service object for one of the services being tracked by this

-	 * <code>ServiceTracker</code> object.

-	 * 

-	 * <p>

-	 * If any services are being tracked, this method returns the result of

-	 * calling <code>getService(getServiceReference())</code>.

-	 * 

-	 * @return Service object or <code>null</code> if no service is being

-	 *         tracked.

-	 */

-	public Object getService() {

-		Object service = cachedService;

-		if (service != null) {

-			if (DEBUG) {

-				System.out

-						.println("ServiceTracker.getService[cached]: " + filter); //$NON-NLS-1$

-			}

-			return service;

-		}

-		if (DEBUG) {

-			System.out.println("ServiceTracker.getService: " + filter); //$NON-NLS-1$

-		}

-		ServiceReference reference = getServiceReference();

-		if (reference == null) {

-			return null;

-		}

-		return cachedService = getService(reference);

-	}

-

-	/**

-	 * Remove a service from this <code>ServiceTracker</code> object.

-	 * 

-	 * The specified service will be removed from this

-	 * <code>ServiceTracker</code> object. If the specified service was being

-	 * tracked then the <code>ServiceTrackerCustomizer.removedService</code>

-	 * method will be called for that service.

-	 * 

-	 * @param reference Reference to the service to be removed.

-	 */

-	public void remove(ServiceReference reference) {

-		Tracked tracked = this.tracked; /*

-										 * use local var since we are not

-										 * synchronized

-										 */

-		if (tracked == null) { /* if ServiceTracker is not open */

-			return;

-		}

-		tracked.untrack(reference);

-	}

-

-	/**

-	 * Return the number of services being tracked by this

-	 * <code>ServiceTracker</code> object.

-	 * 

-	 * @return Number of services being tracked.

-	 */

-	public int size() {

-		Tracked tracked = this.tracked; /*

-										 * use local var since we are not

-										 * synchronized

-										 */

-		if (tracked == null) { /* if ServiceTracker is not open */

-			return 0;

-		}

-		return tracked.size();

-	}

-

-	/**

-	 * Returns the tracking count for this <code>ServiceTracker</code> object.

-	 * 

-	 * The tracking count is initialized to 0 when this

-	 * <code>ServiceTracker</code> object is opened. Every time a service is

-	 * added or removed from this <code>ServiceTracker</code> object the

-	 * tracking count is incremented.

-	 * 

-	 * <p>

-	 * The tracking count can be used to determine if this

-	 * <code>ServiceTracker</code> object has added or removed a service by

-	 * comparing a tracking count value previously collected with the current

-	 * tracking count value. If the value has not changed, then no service has

-	 * been added or removed from this <code>ServiceTracker</code> object

-	 * since the previous tracking count was collected.

-	 * 

-	 * @since 1.2

-	 * @return The tracking count for this <code>ServiceTracker</code> object

-	 *         or -1 if this <code>ServiceTracker</code> object is not open.

-	 */

-	public int getTrackingCount() {

-		return trackingCount;

-	}

-

-	/**

-	 * Called by the Tracked object whenever the set of tracked services is

-	 * modified. Increments the tracking count and clears the cache.

-	 */

-	/*

-	 * This method must not be synchronized since it is called by Tracked while

-	 * Tracked is synchronized. We don't want synchronization interactions

-	 * between the ServiceListener thread and the user thread.

-	 */

-	void modified() {

-		trackingCount++; /* increment modification count */

-		cachedReference = null; /* clear cached value */

-		cachedService = null; /* clear cached value */

-		if (DEBUG) {

-			System.out.println("ServiceTracker.modified: " + filter); //$NON-NLS-1$

-		}

-	}

-

-	/**

-	 * Finalize. This method no longer performs any function but it kept to

-	 * maintain binary compatibility with prior versions of this class.

-	 */

-	protected void finalize() throws Throwable {

-	}

-

-	/**

-	 * Inner class to track services. If a <code>ServiceTracker</code> object

-	 * is reused (closed then reopened), then a new Tracked object is used. This

-	 * class is a hashtable mapping <code>ServiceReference</code> object ->

-	 * customized Object. This class is the <code>ServiceListener</code>

-	 * object for the tracker. This class is used to synchronize access to the

-	 * tracked services. This is not a public class. It is only for use by the

-	 * implementation of the <code>ServiceTracker</code> class.

-	 * 

-	 */

-	class Tracked extends Hashtable implements ServiceListener {

-		static final long			serialVersionUID	= -7420065199791006079L;

-		/**

-		 * List of ServiceReferences in the process of being added. This is used

-		 * to deal with nesting of ServiceEvents. Since ServiceEvents are

-		 * synchronously delivered, ServiceEvents can be nested. For example,

-		 * when processing the adding of a service and the customizer causes the

-		 * service to be unregistered, notification to the nested call to

-		 * untrack that the service was unregistered can be made to the track

-		 * method.

-		 * 

-		 * Since the ArrayList implementation is not synchronized, all access to

-		 * this list must be protected by the same synchronized object for

-		 * thread safety.

-		 */

-		private ArrayList			adding;

-

-		/**

-		 * true if the tracked object is closed.

-		 * 

-		 * This field is volatile because it is set by one thread and read by

-		 * another.

-		 */

-		private volatile boolean	closed;

-

-		/**

-		 * Initial list of ServiceReferences for the tracker. This is used to

-		 * correctly process the initial services which could become

-		 * unregistered before they are tracked. This is necessary since the

-		 * initial set of tracked services are not "announced" by ServiceEvents

-		 * and therefore the ServiceEvent for unregistration could be delivered

-		 * before we track the service.

-		 * 

-		 * A service must not be in both the initial and adding lists at the

-		 * same time. A service must be moved from the initial list to the

-		 * adding list "atomically" before we begin tracking it.

-		 * 

-		 * Since the LinkedList implementation is not synchronized, all access

-		 * to this list must be protected by the same synchronized object for

-		 * thread safety.

-		 */

-		private LinkedList			initial;

-

-		/**

-		 * Tracked constructor.

-		 */

-		protected Tracked() {

-			super();

-			closed = false;

-			adding = new ArrayList(6);

-			initial = new LinkedList();

-		}

-

-		/**

-		 * Set initial list of services into tracker before ServiceEvents begin

-		 * to be received.

-		 * 

-		 * This method must be called from ServiceTracker.open while

-		 * synchronized on this object in the same synchronized block as the

-		 * addServiceListener call.

-		 * 

-		 * @param references The initial list of services to be tracked.

-		 */

-		protected void setInitialServices(ServiceReference[] references) {

-			if (references == null) {

-				return;

-			}

-			int size = references.length;

-			for (int i = 0; i < size; i++) {

-				if (DEBUG) {

-					System.out

-							.println("ServiceTracker.Tracked.setInitialServices: " + references[i]); //$NON-NLS-1$

-				}

-				initial.add(references[i]);

-			}

-		}

-

-		/**

-		 * Track the initial list of services. This is called after

-		 * ServiceEvents can begin to be received.

-		 * 

-		 * This method must be called from ServiceTracker.open while not

-		 * synchronized on this object after the addServiceListener call.

-		 * 

-		 */

-		protected void trackInitialServices() {

-			while (true) {

-				ServiceReference reference;

-				synchronized (this) {

-					if (initial.size() == 0) {

-						/*

-						 * if there are no more inital services

-						 */

-						return; /* we are done */

-					}

-					/*

-					 * move the first service from the initial list to the

-					 * adding list within this synchronized block.

-					 */

-					reference = (ServiceReference) initial.removeFirst();

-					if (this.get(reference) != null) {

-						/* if we are already tracking this service */

-						if (DEBUG) {

-							System.out

-									.println("ServiceTracker.Tracked.trackInitialServices[already tracked]: " + reference); //$NON-NLS-1$

-						}

-						continue; /* skip this service */

-					}

-					if (adding.contains(reference)) {

-						/*

-						 * if this service is already in the process of being

-						 * added.

-						 */

-						if (DEBUG) {

-							System.out

-									.println("ServiceTracker.Tracked.trackInitialServices[already adding]: " + reference); //$NON-NLS-1$

-						}

-						continue; /* skip this service */

-					}

-					adding.add(reference);

-				}

-				if (DEBUG) {

-					System.out

-							.println("ServiceTracker.Tracked.trackInitialServices: " + reference); //$NON-NLS-1$

-				}

-				trackAdding(reference); /*

-										 * Begin tracking it. We call

-										 * trackAdding since we have already put

-										 * the reference in the adding list.

-										 */

-			}

-		}

-

-		/**

-		 * Called by the owning <code>ServiceTracker</code> object when it is

-		 * closed.

-		 */

-		protected void close() {

-			closed = true;

-		}

-

-		/**

-		 * <code>ServiceListener</code> method for the

-		 * <code>ServiceTracker</code> class. This method must NOT be

-		 * synchronized to avoid deadlock potential.

-		 * 

-		 * @param event <code>ServiceEvent</code> object from the framework.

-		 */

-		public void serviceChanged(ServiceEvent event) {

-			/*

-			 * Check if we had a delayed call (which could happen when we

-			 * close).

-			 */

-			if (closed) {

-				return;

-			}

-			ServiceReference reference = event.getServiceReference();

-			if (DEBUG) {

-				System.out

-						.println("ServiceTracker.Tracked.serviceChanged[" + event.getType() + "]: " + reference); //$NON-NLS-1$ //$NON-NLS-2$

-			}

-

-			switch (event.getType()) {

-				case ServiceEvent.REGISTERED :

-				case ServiceEvent.MODIFIED :

-					if (listenerFilter != null) { // constructor supplied

-													// filter

-						track(reference);

-						/*

-						 * If the customizer throws an unchecked exception, it

-						 * is safe to let it propagate

-						 */

-					}

-					else { // user supplied filter

-						if (filter.match(reference)) {

-							track(reference);

-							/*

-							 * If the customizer throws an unchecked exception,

-							 * it is safe to let it propagate

-							 */

-						}

-						else {

-							untrack(reference);

-							/*

-							 * If the customizer throws an unchecked exception,

-							 * it is safe to let it propagate

-							 */

-						}

-					}

-					break;

-				case ServiceEvent.UNREGISTERING :

-					untrack(reference);

-					/*

-					 * If the customizer throws an unchecked exception, it is

-					 * safe to let it propagate

-					 */

-					break;

-			}

-		}

-

-		/**

-		 * Begin to track the referenced service.

-		 * 

-		 * @param reference Reference to a service to be tracked.

-		 */

-		protected void track(ServiceReference reference) {

-			Object object;

-			synchronized (this) {

-				object = this.get(reference);

-			}

-			if (object != null) /* we are already tracking the service */

-			{

-				if (DEBUG) {

-					System.out

-							.println("ServiceTracker.Tracked.track[modified]: " + reference); //$NON-NLS-1$

-				}

-				/* Call customizer outside of synchronized region */

-				customizer.modifiedService(reference, object);

-				/*

-				 * If the customizer throws an unchecked exception, it is safe

-				 * to let it propagate

-				 */

-				return;

-			}

-			synchronized (this) {

-				if (adding.contains(reference)) { /*

-													 * if this service is

-													 * already in the process of

-													 * being added.

-													 */

-					if (DEBUG) {

-						System.out

-								.println("ServiceTracker.Tracked.track[already adding]: " + reference); //$NON-NLS-1$

-					}

-					return;

-				}

-				adding.add(reference); /* mark this service is being added */

-			}

-

-			trackAdding(reference); /*

-									 * call trackAdding now that we have put the

-									 * reference in the adding list

-									 */

-		}

-

-		/**

-		 * Common logic to add a service to the tracker used by track and

-		 * trackInitialServices. The specified reference must have been placed

-		 * in the adding list before calling this method.

-		 * 

-		 * @param reference Reference to a service to be tracked.

-		 */

-		private void trackAdding(ServiceReference reference) {

-			if (DEBUG) {

-				System.out

-						.println("ServiceTracker.Tracked.trackAdding: " + reference); //$NON-NLS-1$

-			}

-			Object object = null;

-			boolean becameUntracked = false;

-			/* Call customizer outside of synchronized region */

-			try {

-				object = customizer.addingService(reference);

-				/*

-				 * If the customizer throws an unchecked exception, it will

-				 * propagate after the finally

-				 */

-			}

-			finally {

-				synchronized (this) {

-					if (adding.remove(reference)) { /*

-													 * if the service was not

-													 * untracked during the

-													 * customizer callback

-													 */

-						if (object != null) {

-							this.put(reference, object);

-							modified(); /* increment modification count */

-							notifyAll(); /*

-											 * notify any waiters in

-											 * waitForService

-											 */

-						}

-					}

-					else {

-						becameUntracked = true;

-					}

-				}

-			}

-			/*

-			 * The service became untracked during the customizer callback.

-			 */

-			if (becameUntracked) {

-				if (DEBUG) {

-					System.out

-							.println("ServiceTracker.Tracked.trackAdding[removed]: " + reference); //$NON-NLS-1$

-				}

-				/* Call customizer outside of synchronized region */

-				customizer.removedService(reference, object);

-				/*

-				 * If the customizer throws an unchecked exception, it is safe

-				 * to let it propagate

-				 */

-			}

-		}

-

-		/**

-		 * Discontinue tracking the referenced service.

-		 * 

-		 * @param reference Reference to the tracked service.

-		 */

-		protected void untrack(ServiceReference reference) {

-			Object object;

-			synchronized (this) {

-				if (initial.remove(reference)) { /*

-													 * if this service is

-													 * already in the list of

-													 * initial references to

-													 * process

-													 */

-					if (DEBUG) {

-						System.out

-								.println("ServiceTracker.Tracked.untrack[removed from initial]: " + reference); //$NON-NLS-1$

-					}

-					return; /*

-							 * we have removed it from the list and it will not

-							 * be processed

-							 */

-				}

-

-				if (adding.remove(reference)) { /*

-												 * if the service is in the

-												 * process of being added

-												 */

-					if (DEBUG) {

-						System.out

-								.println("ServiceTracker.Tracked.untrack[being added]: " + reference); //$NON-NLS-1$

-					}

-					return; /*

-							 * in case the service is untracked while in the

-							 * process of adding

-							 */

-				}

-				object = this.remove(reference); /*

-													 * must remove from tracker

-													 * before calling customizer

-													 * callback

-													 */

-				if (object == null) { /* are we actually tracking the service */

-					return;

-				}

-				modified(); /* increment modification count */

-			}

-			if (DEBUG) {

-				System.out

-						.println("ServiceTracker.Tracked.untrack[removed]: " + reference); //$NON-NLS-1$

-			}

-			/* Call customizer outside of synchronized region */

-			customizer.removedService(reference, object);

-			/*

-			 * If the customizer throws an unchecked exception, it is safe to

-			 * let it propagate

-			 */

-		}

-	}

-

-	/**

-	 * Subclass of Tracked which implements the AllServiceListener interface.

-	 * This class is used by the ServiceTracker if open is called with true.

-	 * 

-	 * @since 1.3

-	 */

-	class AllTracked extends Tracked implements AllServiceListener {

-		static final long	serialVersionUID	= 4050764875305137716L;

-

-		/**

-		 * AllTracked constructor.

-		 */

-		protected AllTracked() {

-			super();

-		}

-	}

-}
\ No newline at end of file
diff --git a/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTrackerCustomizer.java b/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTrackerCustomizer.java
deleted file mode 100644
index a9d7e0f..0000000
--- a/org.osgi/src/main/java/org/osgi/util/tracker/ServiceTrackerCustomizer.java
+++ /dev/null
@@ -1,92 +0,0 @@
-/*

- * $Header: /cvshome/build/org.osgi.util.tracker/src/org/osgi/util/tracker/ServiceTrackerCustomizer.java,v 1.9 2006/03/14 01:20:01 hargrave Exp $

- * 

- * Copyright (c) OSGi Alliance (2000, 2005). All Rights Reserved.

- * 

- * Licensed 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.

- */

-

-package org.osgi.util.tracker;

-

-import org.osgi.framework.ServiceReference;

-

-/**

- * The <code>ServiceTrackerCustomizer</code> interface allows a

- * <code>ServiceTracker</code> object to customize the service objects that are

- * tracked. The <code>ServiceTrackerCustomizer</code> object is called when a

- * service is being added to the <code>ServiceTracker</code> object. The

- * <code>ServiceTrackerCustomizer</code> can then return an object for the tracked

- * service. The <code>ServiceTrackerCustomizer</code> object is also called when a

- * tracked service is modified or has been removed from the

- * <code>ServiceTracker</code> object.

- * 

- * <p>

- * The methods in this interface may be called as the result of a

- * <code>ServiceEvent</code> being received by a <code>ServiceTracker</code> object.

- * Since <code>ServiceEvent</code> s are synchronously delivered by the Framework,

- * it is highly recommended that implementations of these methods do not

- * register (<code>BundleContext.registerService</code>), modify (

- * <code>ServiceRegistration.setProperties</code>) or unregister (

- * <code>ServiceRegistration.unregister</code>) a service while being

- * synchronized on any object.

- * 

- * @version $Revision: 1.9 $

- */

-public interface ServiceTrackerCustomizer {

-	/**

-	 * A service is being added to the <code>ServiceTracker</code> object.

-	 * 

-	 * <p>

-	 * This method is called before a service which matched the search

-	 * parameters of the <code>ServiceTracker</code> object is added to it. This

-	 * method should return the service object to be tracked for this

-	 * <code>ServiceReference</code> object. The returned service object is stored

-	 * in the <code>ServiceTracker</code> object and is available from the

-	 * <code>getService</code> and <code>getServices</code> methods.

-	 * 

-	 * @param reference Reference to service being added to the

-	 *        <code>ServiceTracker</code> object.

-	 * @return The service object to be tracked for the

-	 *         <code>ServiceReference</code> object or <code>null</code> if the

-	 *         <code>ServiceReference</code> object should not be tracked.

-	 */

-	public Object addingService(ServiceReference reference);

-

-	/**

-	 * A service tracked by the <code>ServiceTracker</code> object has been

-	 * modified.

-	 * 

-	 * <p>

-	 * This method is called when a service being tracked by the

-	 * <code>ServiceTracker</code> object has had it properties modified.

-	 * 

-	 * @param reference Reference to service that has been modified.

-	 * @param service The service object for the modified service.

-	 */

-	public void modifiedService(ServiceReference reference,

-			Object service);

-

-	/**

-	 * A service tracked by the <code>ServiceTracker</code> object has been

-	 * removed.

-	 * 

-	 * <p>

-	 * This method is called after a service is no longer being tracked by the

-	 * <code>ServiceTracker</code> object.

-	 * 

-	 * @param reference Reference to service that has been removed.

-	 * @param service The service object for the removed service.

-	 */

-	public void removedService(ServiceReference reference,

-			Object service);

-}
\ No newline at end of file
diff --git a/org.osgi/src/main/resources/LICENSE b/org.osgi/src/main/resources/LICENSE
new file mode 100644
index 0000000..d645695
--- /dev/null
+++ b/org.osgi/src/main/resources/LICENSE
@@ -0,0 +1,202 @@
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed 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.
diff --git a/org.osgi/src/main/resources/about.html b/org.osgi/src/main/resources/about.html
new file mode 100644
index 0000000..eb1ec76
--- /dev/null
+++ b/org.osgi/src/main/resources/about.html
@@ -0,0 +1,40 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
+<!-- $Header: /cvshome/build/osgi/about.html,v 1.3 2006/03/14 01:21:34 hargrave Exp $ -->
+<html>
+<head>
+<title>About</title>
+<meta http-equiv=Content-Type content="text/html; charset=ISO-8859-1">
+</head>
+<body lang="EN-US">
+<h2>About This Content</h2>
+ 
+<h3>Copyright</h3>
+<p>Copyright (c) 2000, 2005</p>
+
+<p>OSGi Alliance<br/>
+Bishop Ranch 6<br/>
+2400 Camino Ramon, Suite 375<br/>
+San Ramon, CA 94583 USA
+</p>
+<p>All Rights Reserved.</p>
+
+<h3>License</h3>
+<p>The OSGi Alliance makes available all content in this jar (&quot;Work&quot;).  Unless otherwise indicated below, the Work is provided to you under the terms and conditions of the
+Apache License, Version 2.0 (the &quot;License&quot;).  A copy of the License is available at <a href="http://www.apache.org/licenses/LICENSE-2.0">http://www.apache.org/licenses/LICENSE-2.0</a>.</p>
+
+<h3>Notices</h3>
+<p>Implementation of certain elements of the Content may be subject to third party
+intellectual property rights, including without limitation, patent rights (such a third party may
+or may not be a member of the OSGi Alliance). The OSGi Alliance and its members are not responsible 
+and shall not be held responsible in any manner for identifying or failing to identify any or 
+all such third party intellectual property rights.</p>
+
+<p>OSGi&trade; is a trademark, registered trademark, or service mark
+of The OSGi Alliance in the US and other countries. Java is a trademark,
+registered trademark, or service mark of Sun Microsystems, Inc. in the US
+and other countries. All other trademarks, registered trademarks, or
+service marks used in the Content are the property of their respective
+owners and are hereby recognized.</p>
+
+</body>
+</html>
\ No newline at end of file