[jboss-remoting-commits] JBoss Remoting SVN: r5584 - in remoting3/trunk: jboss-remoting/src/main/java/org/jboss/remoting3/spi and 1 other directories.

jboss-remoting-commits at lists.jboss.org jboss-remoting-commits at lists.jboss.org
Wed Nov 4 18:31:39 EST 2009


Author: david.lloyd at jboss.com
Date: 2009-11-04 18:31:39 -0500 (Wed, 04 Nov 2009)
New Revision: 5584

Modified:
   remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/EndpointImpl.java
   remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionHandlerContext.java
   remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionProviderContext.java
   remoting3/trunk/taglet/pom.xml
Log:
Minor cleanup

Modified: remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/EndpointImpl.java
===================================================================
--- remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/EndpointImpl.java	2009-11-04 23:19:07 UTC (rev 5583)
+++ remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/EndpointImpl.java	2009-11-04 23:31:39 UTC (rev 5584)
@@ -114,11 +114,14 @@
 
     private final ConcurrentMap<Registration, ServiceRegistrationListener> serviceListenerRegistrations = concurrentIdentityMap(serviceRegistrationLock);
     private final ConcurrentMap<String, ConcurrentMap<String, ServiceRegistration>> registeredLocalServices = concurrentMap(serviceRegistrationLock);
-
     private final ConcurrentMap<String, ConnectionProvider<?>> connectionProviders = concurrentMap();
-
     private final ConcurrentMap[] providerMaps = new ConcurrentMap[ProtocolServiceType.getServiceTypes().length];
 
+    private final ConnectionProviderContext connectionProviderContext;
+    private final ConnectionHandler loopbackConnectionHandler;
+    private final Connection loopbackConnection;
+    private final ConnectionHandlerContext localConnectionContext;
+
     private static final EndpointPermission CREATE_ENDPOINT_PERM = new EndpointPermission("createEndpoint");
     private static final EndpointPermission CREATE_REQUEST_HANDLER_PERM = new EndpointPermission("createRequestHandler");
     private static final EndpointPermission REGISTER_SERVICE_PERM = new EndpointPermission("registerService");
@@ -140,6 +143,10 @@
         this.executor = executor;
         this.name = name;
         connectionProviders.put("local", new LocalConnectionProvider());
+        connectionProviderContext = new ConnectionProviderContextImpl();
+        loopbackConnectionHandler = new LoopbackConnectionHandler();
+        loopbackConnection = new LoopbackConnection();
+        localConnectionContext = new LocalConnectionContext(null, loopbackConnection);
     }
 
     private final Executor executor;
@@ -454,7 +461,7 @@
         final FutureResult<Connection> futureResult = new FutureResult<Connection>(executor);
         futureResult.addCancelHandler(connectionProvider.connect(destination, connectOptions, new TranslatingResult<ConnectionHandlerFactory, Connection>(futureResult) {
             protected Connection translate(final ConnectionHandlerFactory input) {
-                return new ConnectionImpl(input);
+                return new ConnectionImpl(input, connectionProviderContext);
             }
         }));
         return futureResult.getIoFuture();
@@ -542,12 +549,18 @@
     }
 
     private final class LocalConnectionContext implements ConnectionHandlerContext {
+        private final ConnectionProviderContext connectionProviderContext;
         private final Connection connection;
 
-        LocalConnectionContext(final Connection connection) {
+        LocalConnectionContext(final ConnectionProviderContext connectionProviderContext, final Connection connection) {
+            this.connectionProviderContext = connectionProviderContext;
             this.connection = connection;
         }
 
+        public ConnectionProviderContext getConnectionProviderContext() {
+            return connectionProviderContext;
+        }
+
         public void openService(final String serviceType, final String groupName, final OptionMap optionMap, final ServiceResult serviceResult) {
             final String canonServiceType = serviceType.toLowerCase();
             final String canonGroupName = groupName.toLowerCase();
@@ -599,9 +612,9 @@
     private class ConnectionImpl extends AbstractHandleableCloseable<Connection> implements Connection {
         private final ConnectionHandler connectionHandler;
 
-        private ConnectionImpl(final ConnectionHandlerFactory connectionHandlerFactory) {
+        private ConnectionImpl(final ConnectionHandlerFactory connectionHandlerFactory, final ConnectionProviderContext connectionProviderContext) {
             super(EndpointImpl.this.executor);
-            connectionHandler = connectionHandlerFactory.createInstance(new LocalConnectionContext(this));
+            connectionHandler = connectionHandlerFactory.createInstance(new LocalConnectionContext(connectionProviderContext, this));
         }
 
         protected void closeAction() throws IOException {
@@ -646,10 +659,6 @@
         }
     }
 
-    private final ConnectionHandler loopbackConnectionHandler = new LoopbackConnectionHandler();
-    private final Connection loopbackConnection = new LoopbackConnection();
-    private final ConnectionHandlerContext localConnectionContext = new LocalConnectionContext(loopbackConnection);
-
     private final class LocalConnectionProvider implements ConnectionProvider<Void> {
 
         public Cancellable connect(final URI uri, final OptionMap connectOptions, final Result<ConnectionHandlerFactory> result) throws IllegalArgumentException {

Modified: remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionHandlerContext.java
===================================================================
--- remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionHandlerContext.java	2009-11-04 23:19:07 UTC (rev 5583)
+++ remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionHandlerContext.java	2009-11-04 23:31:39 UTC (rev 5584)
@@ -25,13 +25,20 @@
 import org.jboss.xnio.OptionMap;
 
 /**
- * The context for connections to service incoming requests to open a client service.
+ * The context for connection handlers.  Used to inform the endpoint of incoming events on an established connection.
  *
  * @remoting.consume
  */
 public interface ConnectionHandlerContext {
 
     /**
+     * Get the connection provider context associated with this connection handler context.
+     *
+     * @return the connection provider context
+     */
+    ConnectionProviderContext getConnectionProviderContext();
+
+    /**
      * Open a service.
      *
      * @remoting.nonblocking

Modified: remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionProviderContext.java
===================================================================
--- remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionProviderContext.java	2009-11-04 23:19:07 UTC (rev 5583)
+++ remoting3/trunk/jboss-remoting/src/main/java/org/jboss/remoting3/spi/ConnectionProviderContext.java	2009-11-04 23:31:39 UTC (rev 5584)
@@ -26,7 +26,8 @@
 import java.util.Map;
 
 /**
- * A context for a connection provider which provides a means to accept a connection.
+ * A context for a connection provider.  This provides additional endpoint methods to connection providers which are not
+ * accessible otherwise.
  *
  * @remoting.consume
  */

Modified: remoting3/trunk/taglet/pom.xml
===================================================================
--- remoting3/trunk/taglet/pom.xml	2009-11-04 23:19:07 UTC (rev 5583)
+++ remoting3/trunk/taglet/pom.xml	2009-11-04 23:31:39 UTC (rev 5584)
@@ -28,6 +28,8 @@
 
     <groupId>org.jboss.remoting</groupId>
     <artifactId>jboss-remoting-taglet</artifactId>
+    <name>JBoss Remoting Taglet</name>
+    <description>JBoss Remoting Documentation Taglet</description>
     <packaging>jar</packaging>
     <version>3.1.0.CR1</version>
 



More information about the jboss-remoting-commits mailing list