You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@directory.apache.org by go...@apache.org on 2012/05/10 15:34:45 UTC
svn commit: r1336682 - in
/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core: ./
src/ src/main/ src/main/java/ src/main/java/org/ src/main/java/org/apache/
src/main/java/org/apache/directory/
src/main/java/org/apache/directory/server/...
Author: gokturk
Date: Thu May 10 13:34:44 2012
New Revision: 1336682
URL: http://svn.apache.org/viewvc?rev=1336682&view=rev
Log:
Implementation of IPojo connector for ComponentHub,
It works with apacheds-hub-connector-ipojo-handler to wire ApacheDS components into ComponentHub system.
Added:
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/pom.xml
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/Activator.java
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/DCMetadataBuilder.java
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoConnector.java
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoFactoryTracker.java
directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoOperations.java
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/pom.xml
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/pom.xml?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/pom.xml (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/pom.xml Thu May 10 13:34:44 2012
@@ -0,0 +1,73 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+ 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.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>org.apache.directory.server</groupId>
+ <artifactId>apacheds-hub-connector-ipojo</artifactId>
+ <version>2.0.0-M7-SNAPSHOT</version>
+ </parent>
+ <artifactId>apacheds-hub-connector-ipojo-core</artifactId>
+ <name>Component Hub IPojo Connector</name>
+ <description>Component Hub IPojo Connector</description>
+
+ <packaging>bundle</packaging>
+
+ <dependencies>
+ <dependency>
+ <groupId>org.apache.directory.server</groupId>
+ <artifactId>apacheds-hub-api</artifactId>
+ </dependency>
+
+ <dependency>
+ <groupId>org.apache.directory.server</groupId>
+ <artifactId>apacheds-hub-connector-ipojo-handler</artifactId>
+ </dependency>
+
+ <dependency>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>org.apache.felix.ipojo</artifactId>
+ </dependency>
+ </dependencies>
+
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>maven-bundle-plugin</artifactId>
+ <inherited>true</inherited>
+ <extensions>true</extensions>
+ <configuration>
+ <manifestLocation>META-INF</manifestLocation>
+ <unpackBundle>true</unpackBundle>
+ <instructions>
+ <Bundle-SymbolicName>${project.groupId}.connector.ipojo</Bundle-SymbolicName>
+ <Bundle-Activator>org.apache.directory.server.hub.connector.ipojo.core.Activator</Bundle-Activator>
+ <Export-Package>
+ {local-packages};version=${project.version};-noimport:=true
+ </Export-Package>
+ </instructions>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+
+</project>
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/Activator.java
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/Activator.java?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/Activator.java (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/Activator.java Thu May 10 13:34:44 2012
@@ -0,0 +1,26 @@
+package org.apache.directory.server.hub.connector.ipojo.core;
+
+
+import org.osgi.framework.BundleActivator;
+import org.osgi.framework.BundleContext;
+
+
+public class Activator implements BundleActivator
+{
+ @Override
+ public void start( BundleContext context ) throws Exception
+ {
+ IPojoConnector.connectorContext = context;
+
+ IPojoFactoryTracker tracker = new IPojoFactoryTracker( new IPojoConnector() );
+ tracker.open();
+ }
+
+
+ @Override
+ public void stop( BundleContext context ) throws Exception
+ {
+ IPojoConnector.connectorContext = null;
+ }
+
+}
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/DCMetadataBuilder.java
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/DCMetadataBuilder.java?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/DCMetadataBuilder.java (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/DCMetadataBuilder.java Thu May 10 13:34:44 2012
@@ -0,0 +1,140 @@
+package org.apache.directory.server.hub.connector.ipojo.core;
+
+
+import java.lang.reflect.Array;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.directory.server.component.handler.ipojo.property.DirectoryPropertyDescription;
+import org.apache.directory.server.hub.api.component.util.ComponentConstants;
+import org.apache.directory.server.hub.api.meta.DCMetadataDescriptor;
+import org.apache.directory.server.hub.api.meta.DCPropertyDescription;
+import org.apache.directory.server.hub.api.meta.DCPropertyType;
+import org.apache.felix.ipojo.ComponentFactory;
+import org.apache.felix.ipojo.architecture.ComponentTypeDescription;
+import org.apache.felix.ipojo.architecture.PropertyDescription;
+import org.apache.felix.ipojo.metadata.Element;
+import org.osgi.framework.Version;
+
+
+public class DCMetadataBuilder
+{
+ public static DCMetadataDescriptor generateDCMetadata( ComponentFactory factory )
+ {
+ String metadataPID = factory.getName();
+ Version metaVersion = factory.getBundleContext().getBundle().getVersion();
+
+ List<DCPropertyDescription> properties = new ArrayList<DCPropertyDescription>();
+
+ for ( PropertyDescription property : factory.getComponentDescription().getProperties() )
+ {
+ String name = property.getName();
+ String defaultValue = property.getValue();
+ boolean mandatory = property.isMandatory();
+ String type = normalizeType( property.getType() );
+ String description = "";
+ String containerFor = "";
+
+ DirectoryPropertyDescription dpd = ( DirectoryPropertyDescription ) property;
+ if ( dpd != null )
+ {
+ description = dpd.getDesc();
+ containerFor = normalizeType( dpd.getContainerType() );
+ }
+
+ if ( property.isImmutable() )
+ {
+ properties.add( new DCPropertyDescription( DCPropertyType.CONSTANT, name, type,
+ defaultValue, description, mandatory, containerFor ) );
+ }
+ else
+ {
+ properties.add( new DCPropertyDescription( name, type,
+ defaultValue, description, mandatory, containerFor ) );
+ }
+ }
+
+ ComponentTypeDescription typeDescription = factory.getComponentTypeDescription();
+ Element desc = typeDescription.getDescription();
+
+ String className = desc.getAttribute( "Implementation-Class" );
+
+ Element inheritance = desc.getElements( "Inherited" )[0];
+
+ String interfaces = inheritance.getAttribute( "Interfaces" );
+ String sclasses = inheritance.getAttribute( "SuperClasses" );
+
+ String[] implemented = parseArray( interfaces );
+ String[] extended = parseArray( sclasses );
+
+ DCMetadataDescriptor metadata = new DCMetadataDescriptor( metadataPID, true, metaVersion, className,
+ implemented, extended, properties.toArray( new DCPropertyDescription[0] ) );
+
+ return metadata;
+ }
+
+
+ private static String[] parseArray( String array )
+ {
+ if ( !( array.contains( "[" ) && array.contains( "]" ) ) )
+ {
+ return new String[0];
+ }
+
+ array = array.substring( 1, array.length() - 1 );
+
+ String[] splitted = array.split( "," );
+
+ return splitted;
+ }
+
+
+ private static String normalizeType( String type )
+ {
+ if ( type.endsWith( "[]" ) )
+ {
+ return Array.class.getName();
+ }
+ else
+ {
+ if ( "string".equals( type ) || "String".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_STR;
+ }
+ else if ( "boolean".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_BOOL;
+ }
+ else if ( "byte".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_INT;
+ }
+ else if ( "short".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_INT;
+ }
+ else if ( "int".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_INT;
+ }
+ else if ( "long".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_INT;
+ }
+ else if ( "float".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_FLOAT;
+ }
+ else if ( "double".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_FLOAT;
+ }
+ else if ( "char".equals( type ) )
+ {
+ return ComponentConstants.PRIMITIVE_INT;
+ }
+ else
+ return type;
+ }
+ }
+}
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoConnector.java
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoConnector.java?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoConnector.java (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoConnector.java Thu May 10 13:34:44 2012
@@ -0,0 +1,96 @@
+package org.apache.directory.server.hub.connector.ipojo.core;
+
+
+import java.util.HashSet;
+import java.util.Set;
+
+import org.apache.directory.server.hub.api.ComponentHub;
+import org.apache.directory.server.hub.api.HubConnector;
+import org.apache.directory.server.hub.api.component.util.ComponentConstants;
+import org.apache.directory.server.hub.api.exception.HubAbortException;
+import org.apache.directory.server.hub.api.meta.DCMetadataDescriptor;
+import org.apache.directory.server.hub.api.meta.DCOperationsManager;
+import org.apache.felix.ipojo.ComponentFactory;
+import org.apache.felix.ipojo.architecture.PropertyDescription;
+import org.osgi.framework.BundleContext;
+
+
+public class IPojoConnector implements HubConnector
+{
+ public static BundleContext connectorContext;
+
+ private ComponentHub hub;
+
+ private IPojoFactoryTracker tracker;
+
+ private Set<String> managedFactories = new HashSet<String>();
+
+
+ @Override
+ public void init( ComponentHub hub )
+ {
+ if ( connectorContext == null )
+ {
+ //TODO Error log.
+ return;
+ }
+
+ this.hub = hub;
+
+ tracker = new IPojoFactoryTracker( this );
+ tracker.open();
+ }
+
+
+ public void factoryActivated( ComponentFactory factory )
+ {
+ if ( isDirectoryFactory( factory ) )
+ {
+ DCMetadataDescriptor metadata = DCMetadataBuilder.generateDCMetadata( factory );
+ DCOperationsManager operationsManager = new IPojoOperations( factory );
+
+ try
+ {
+ hub.connectHandler( metadata, operationsManager );
+ managedFactories.add( factory.getName() );
+ }
+ catch ( HubAbortException e )
+ {
+ }
+ }
+ }
+
+
+ public void factoryDeactivating( ComponentFactory factory )
+ {
+ if ( managedFactories.contains( factory.getName() ) )
+ {
+ hub.disconnectHandler( factory.getName() );
+ }
+ }
+
+
+ private boolean isDirectoryFactory( ComponentFactory factory )
+ {
+ PropertyDescription[] properties = factory.getComponentTypeDescription().getProperties();
+
+ for ( PropertyDescription pd : properties )
+ {
+ if ( pd.getName().equals( ComponentConstants.DC_NATURE_INDICATOR ) )
+ {
+ if ( Boolean.parseBoolean( pd.getValue() ) )
+ {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+
+ public BundleContext getContext()
+ {
+ return connectorContext;
+ }
+}
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoFactoryTracker.java
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoFactoryTracker.java?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoFactoryTracker.java (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoFactoryTracker.java Thu May 10 13:34:44 2012
@@ -0,0 +1,94 @@
+package org.apache.directory.server.hub.connector.ipojo.core;
+
+
+import org.apache.felix.ipojo.ComponentFactory;
+import org.apache.felix.ipojo.Factory;
+import org.apache.felix.ipojo.FactoryStateListener;
+import org.osgi.framework.BundleContext;
+import org.osgi.framework.ServiceReference;
+import org.osgi.util.tracker.ServiceTracker;
+import org.osgi.util.tracker.ServiceTrackerCustomizer;
+
+
+public class IPojoFactoryTracker implements FactoryStateListener, ServiceTrackerCustomizer
+{
+ BundleContext context;
+ ServiceTracker tracker;
+ IPojoConnector connector;
+
+
+ public IPojoFactoryTracker( IPojoConnector connector )
+ {
+ this.connector = connector;
+ context = connector.getContext();
+
+ tracker = new ServiceTracker( context, Factory.class.getName(), this );
+ }
+
+
+ public void open()
+ {
+ tracker.open();
+ }
+
+
+ public void close()
+ {
+ tracker.close();
+ }
+
+
+ @Override
+ public void stateChanged( Factory factory, int state )
+ {
+ ComponentFactory componentFactory = ( ComponentFactory ) factory;
+
+ if ( state == Factory.VALID )
+ {
+ connector.factoryActivated( componentFactory );
+ }
+ else if ( state == Factory.INVALID )
+ {
+ connector.factoryDeactivating( componentFactory );
+ }
+
+ }
+
+
+ @Override
+ public Object addingService( ServiceReference reference )
+ {
+ Factory factory = context.getService( ( ServiceReference<Factory> ) reference );
+
+ ComponentFactory componentFactory = ( ComponentFactory ) factory;
+ if ( componentFactory == null )
+ {
+ return null;
+ }
+
+ System.out.println(factory.getName()+"adding");
+
+ componentFactory.addFactoryStateListener( this );
+
+ if ( componentFactory.getState() == Factory.VALID )
+ {
+ connector.factoryActivated( componentFactory );
+ }
+
+ return reference;
+
+ }
+
+
+ @Override
+ public void modifiedService( ServiceReference reference, Object service )
+ {
+ }
+
+
+ @Override
+ public void removedService( ServiceReference reference, Object service )
+ {
+ }
+
+}
Added: directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoOperations.java
URL: http://svn.apache.org/viewvc/directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoOperations.java?rev=1336682&view=auto
==============================================================================
--- directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoOperations.java (added)
+++ directory/apacheds/branches/apacheds-osgi/hub/connectors/ipojo/core/src/main/java/org/apache/directory/server/hub/connector/ipojo/core/IPojoOperations.java Thu May 10 13:34:44 2012
@@ -0,0 +1,126 @@
+package org.apache.directory.server.hub.connector.ipojo.core;
+
+
+import java.util.Dictionary;
+import java.util.Hashtable;
+
+import org.apache.directory.server.hub.api.component.DCProperty;
+import org.apache.directory.server.hub.api.component.DCRuntime;
+import org.apache.directory.server.hub.api.component.DirectoryComponent;
+import org.apache.directory.server.hub.api.exception.ComponentInstantiationException;
+import org.apache.directory.server.hub.api.exception.ComponentReconfigurationException;
+import org.apache.directory.server.hub.api.meta.DCOperationsManager;
+import org.apache.felix.ipojo.ComponentFactory;
+import org.apache.felix.ipojo.ComponentInstance;
+import org.apache.felix.ipojo.ConfigurationException;
+import org.apache.felix.ipojo.InstanceManager;
+import org.apache.felix.ipojo.MissingHandlerException;
+import org.apache.felix.ipojo.UnacceptableConfiguration;
+
+
+public class IPojoOperations implements DCOperationsManager
+{
+
+ private ComponentFactory factory;
+
+
+ public IPojoOperations( ComponentFactory factory )
+ {
+ this.factory = factory;
+ }
+
+
+ @Override
+ public void instantiateComponent( DirectoryComponent component ) throws ComponentInstantiationException
+ {
+ Dictionary<String, Object> configuration = new Hashtable<String, Object>();
+ for ( DCProperty prop : component.getConfiguration() )
+ {
+ configuration.put( prop.getName(), prop.getObject() );
+ }
+
+ configuration.put( "instance.name", component.getComponentPID() );
+
+ try
+ {
+ ComponentInstance instance = factory.createComponentInstance( configuration );
+
+ InstanceManager manager = ( InstanceManager ) instance;
+ Object pojo = manager.getPojoObject();
+
+ component.setRuntimeInfo( new DCRuntime( manager, pojo ) );
+ }
+ catch ( UnacceptableConfiguration e )
+ {
+ throw new ComponentInstantiationException( "Configuration unacceptable for component"
+ + component.getComponentPID(), e );
+ }
+ catch ( MissingHandlerException e )
+ {
+ throw new ComponentInstantiationException( "Missing handler for component:" + component.getComponentPID(),
+ e );
+ }
+ catch ( ConfigurationException e )
+ {
+ throw new ComponentInstantiationException( "Configuration failed for component:"
+ + component.getComponentPID(), e );
+ }
+ }
+
+
+ @Override
+ public void reconfigureComponent( DirectoryComponent component ) throws ComponentReconfigurationException
+ {
+ DCRuntime runtime = component.getRuntimeInfo();
+ if ( runtime == null || runtime.getSpecialObject() == null )
+ {
+ throw new ComponentReconfigurationException( "Failed to reconfigure disposed component:"
+ + component.getComponentPID() );
+ }
+
+ InstanceManager manager = ( InstanceManager ) runtime.getSpecialObject();
+
+ if ( manager.getState() != InstanceManager.VALID )
+ {
+ throw new ComponentReconfigurationException( "Failed to reconfigure disactivated component:"
+ + component.getComponentPID() );
+ }
+
+ Dictionary<String, Object> configuration = new Hashtable<String, Object>();
+ for ( DCProperty prop : component.getConfiguration() )
+ {
+ configuration.put( prop.getName(), prop.getObject() );
+ }
+
+ configuration.put( "instance.name", component.getComponentPID() );
+
+ manager.reconfigure( configuration );
+
+ if ( manager.getState() != InstanceManager.VALID )
+ {
+ throw new ComponentReconfigurationException( "Reconfiguration stopped the component:"
+ + component.getComponentPID() );
+ }
+ }
+
+
+ @Override
+ public void disposeComponent( DirectoryComponent component )
+ {
+ DCRuntime runtime = component.getRuntimeInfo();
+ if ( runtime == null || runtime.getSpecialObject() == null )
+ {
+ component.setRuntimeInfo( null );
+ return;
+ }
+
+ InstanceManager manager = ( InstanceManager ) runtime.getSpecialObject();
+ if ( manager.getState() != InstanceManager.DISPOSED )
+ {
+ manager.dispose();
+ }
+
+ component.setRuntimeInfo( null );
+ }
+
+}