Author: slaws
Date: Thu Mar 20 06:02:37 2008
New Revision: 639277

URL: http://svn.apache.org/viewvc?rev=639277&view=rev
Log:
TUSCANY-2099
Applied Giorgios patch which includes more steps on the way to getting the 
workpool demo going with the latest code in trunk. Thanks Giogio

Modified:
    incubator/tuscany/java/sca/demos/workpool-distributed/pom.xml
    
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/ArtifactsFinder.java
    
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/CompositeUpdaterImpl.java
    
incubator/tuscany/java/sca/modules/core/src/main/java/org/apache/tuscany/sca/core/assembly/CompositeActivatorImpl.java

Modified: incubator/tuscany/java/sca/demos/workpool-distributed/pom.xml
URL: 
http://svn.apache.org/viewvc/incubator/tuscany/java/sca/demos/workpool-distributed/pom.xml?rev=639277&r1=639276&r2=639277&view=diff
==============================================================================
--- incubator/tuscany/java/sca/demos/workpool-distributed/pom.xml (original)
+++ incubator/tuscany/java/sca/demos/workpool-distributed/pom.xml Thu Mar 20 
06:02:37 2008
@@ -1,126 +1,143 @@
 <?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.    
+       * 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>
-<modelVersion>4.0.0</modelVersion>
-    <parent>
-        <groupId>org.apache.tuscany.sca</groupId>
-        <artifactId>tuscany-sca</artifactId>
-        <version>2.0-incubating-SNAPSHOT</version>
-        <relativePath>../../pom.xml</relativePath>
-    </parent>
-    <artifactId>demo-workpool-distributed</artifactId>
-    <name>Apache Tuscany SCA Distributed Job Workpool Demo</name>
-
-    <repositories>
-       <repository>
-          <id>apache.incubator</id>
-          <url>http://people.apache.org/repo/m2-incubating-repository</url>
-       </repository>
-    </repositories>
+       <modelVersion>4.0.0</modelVersion>
+       <parent>
+               <groupId>org.apache.tuscany.sca</groupId>
+               <artifactId>tuscany-sca</artifactId>
+               <version>2.0-incubating-SNAPSHOT</version>
+               <relativePath>../../pom.xml</relativePath>
+       </parent>
+       <artifactId>demo-workpool-distributed</artifactId>
+       <name>Apache Tuscany SCA Distributed Job Workpool Demo</name>
 
-    <dependencies>
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-host-embedded</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>
-        
-       <dependency>
-            <groupId>antlr</groupId>
-            <artifactId>antlr</artifactId>
-            <version>2.7.1</version>
-       </dependency>
+       <repositories>
+               <repository>
+                       <id>apache.incubator</id>
+                       <url>
+                               
http://people.apache.org/repo/m2-incubating-repository
+                       </url>
+               </repository>
+        <repository>
+            <id>org.drools</id>
+            <url>http://repository.jboss.com/maven2/org/drools/</url>
+        </repository>
+       </repositories>
 
-        <dependency>
-           <groupId>antlr</groupId>
-           <artifactId>stringtemplate</artifactId>
-           <version>2.3b6</version>
-       </dependency>
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-node-impl</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>    
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-domain-impl</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>                                
+       <dependencies>
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-host-embedded</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
 
         <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-binding-sca-axis2</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>   
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-binding-jsonrpc</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency> 
-  
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-binding-http</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-            <scope>runtime</scope>
-        </dependency>        
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-databinding-job</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>        
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-databinding-xstream</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-        </dependency>        
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-implementation-resource</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-            <scope>runtime</scope>
-        </dependency>   
-        
-        <dependency>
-            <groupId>org.apache.tuscany.sca</groupId>
-            <artifactId>tuscany-host-tomcat</artifactId>
-            <version>2.0-incubating-SNAPSHOT</version>
-            <scope>test</scope>
-        </dependency>          
-        
-        <dependency>
-            <groupId>junit</groupId>
-            <artifactId>junit</artifactId>
-            <version>4.2</version>
-            <scope>test</scope>
+                       <groupId>org.drools</groupId>
+                       <artifactId>drools</artifactId>
+                       <version>4.0.4</version>
         </dependency>
-                
-    </dependencies>
 
-    <build>
-       <finalName>${artifactId}</finalName>
-    </build>
+               <dependency>
+                       <groupId>antlr</groupId>
+                       <artifactId>antlr</artifactId>
+                       <version>2.7.1</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>antlr</groupId>
+                       <artifactId>stringtemplate</artifactId>
+                       <version>2.3b6</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-node-impl</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-domain-impl</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-binding-sca-axis2</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-binding-jsonrpc</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-binding-http</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+                       <scope>runtime</scope>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-databinding-job</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-contribution-updater</artifactId>
+                       <version>1.2-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-databinding-xstream</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-implementation-resource</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+                       <scope>runtime</scope>
+               </dependency>
+
+               <dependency>
+                       <groupId>org.apache.tuscany.sca</groupId>
+                       <artifactId>tuscany-host-tomcat</artifactId>
+                       <version>2.0-incubating-SNAPSHOT</version>
+                       <scope>test</scope>
+               </dependency>
+
+               <dependency>
+                       <groupId>junit</groupId>
+                       <artifactId>junit</artifactId>
+                       <version>4.2</version>
+                       <scope>test</scope>
+               </dependency>
+
+       </dependencies>
+
+       <build>
+               <finalName>${artifactId}</finalName>
+       </build>
 </project>

Modified: 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/ArtifactsFinder.java
URL: 
http://svn.apache.org/viewvc/incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/ArtifactsFinder.java?rev=639277&r1=639276&r2=639277&view=diff
==============================================================================
--- 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/ArtifactsFinder.java
 (original)
+++ 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/ArtifactsFinder.java
 Thu Mar 20 06:02:37 2008
@@ -28,14 +28,11 @@
 public class ArtifactsFinder {
 
     public static Composite findComposite(String compositeURI,
-            List<DeployedArtifact> artifacts) {
-        for (DeployedArtifact artifact : artifacts) {
-            if (artifact.getModel() instanceof Composite) {
-                Composite composite = (Composite) artifact.getModel();
+            List<Composite> artifacts) {
+        for (Composite composite : artifacts) {
                 if (composite.getURI().equals(compositeURI))
                     return composite;
             }
-        }
         return null;
     }
 

Modified: 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/CompositeUpdaterImpl.java
URL: 
http://svn.apache.org/viewvc/incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/CompositeUpdaterImpl.java?rev=639277&r1=639276&r2=639277&view=diff
==============================================================================
--- 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/CompositeUpdaterImpl.java
 (original)
+++ 
incubator/tuscany/java/sca/modules/contribution-updater-impl/src/main/java/org/apache/tuscany/sca/contribution/updater/impl/CompositeUpdaterImpl.java
 Thu Mar 20 06:02:37 2008
@@ -26,6 +26,7 @@
 import org.apache.tuscany.sca.assembly.MetaComponent;
 import org.apache.tuscany.sca.assembly.builder.CompositeBuilder;
 import org.apache.tuscany.sca.assembly.builder.impl.CompositeBuilderImpl;
+import org.apache.tuscany.sca.contribution.Artifact;
 import org.apache.tuscany.sca.contribution.Contribution;
 import org.apache.tuscany.sca.contribution.DeployedArtifact;
 import 
org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessorExtensionPoint;
@@ -110,7 +111,7 @@
 
     public Component findComponent(String componentName) {
         Contribution contrib = contribService.getContribution(contribURI);
-        List<DeployedArtifact> artifacts = contrib.getArtifacts();
+        List<Composite> artifacts = contrib.getDeployables();
         Composite composite = ArtifactsFinder.findComposite(compositeURI,
                 artifacts);
         return ArtifactsFinder.findComponent(composite, componentName);

Modified: 
incubator/tuscany/java/sca/modules/core/src/main/java/org/apache/tuscany/sca/core/assembly/CompositeActivatorImpl.java
URL: 
http://svn.apache.org/viewvc/incubator/tuscany/java/sca/modules/core/src/main/java/org/apache/tuscany/sca/core/assembly/CompositeActivatorImpl.java?rev=639277&r1=639276&r2=639277&view=diff
==============================================================================
--- 
incubator/tuscany/java/sca/modules/core/src/main/java/org/apache/tuscany/sca/core/assembly/CompositeActivatorImpl.java
 (original)
+++ 
incubator/tuscany/java/sca/modules/core/src/main/java/org/apache/tuscany/sca/core/assembly/CompositeActivatorImpl.java
 Thu Mar 20 06:02:37 2008
@@ -152,6 +152,20 @@
             }
         }
     }
+    
+    public void stop(Component component, ComponentReference reference)
+    {
+        if (logger.isLoggable(Level.FINE)) {
+            logger.fine("Starting component reference: " + component.getURI() 
+ "#" + reference.getName());
+        }
+        RuntimeComponentReference runtimeRef = 
((RuntimeComponentReference)reference);
+        for (Binding binding : reference.getBindings()) {
+            ReferenceBindingProvider bindingProvider = 
runtimeRef.getBindingProvider(binding);
+            if (bindingProvider != null) {
+                bindingProvider.stop();
+            }
+        }
+    }    
 
     public void deactivate(RuntimeComponent component, 
RuntimeComponentReference ref) {
         if (logger.isLoggable(Level.FINE)) {
@@ -761,6 +775,64 @@
         }        
         runtimeComponent.setScopeContainer(null);
     }
+    
+    public void activateComponent(Component component)
+            throws ActivationException {
+        try {
+            if (logger.isLoggable(Level.FINE)) {
+                logger.fine("Activating component: " + component.getURI());
+            }
+
+            Implementation implementation = component.getImplementation();
+            if (implementation instanceof Composite) {
+                activate((Composite) implementation);
+            } else if (implementation != null) {
+                addImplementationProvider((RuntimeComponent) component,
+                        implementation);
+                addScopeContainer(component);
+            }
+
+            for (ComponentService service : component.getServices()) {
+                activate((RuntimeComponent) component,
+                        (RuntimeComponentService) service);
+            }
+
+            for (ComponentReference reference : component.getReferences()) {
+                activate((RuntimeComponent) component,
+                        (RuntimeComponentReference) reference);
+            }
+        } catch (Exception e) {
+            throw new ActivationException(e);
+        }
+    }
+
+    public void deactivateComponent(Component component)
+            throws ActivationException {
+        try {
+            if (logger.isLoggable(Level.FINE)) {
+                logger.fine("Deactivating component: " + component.getURI());
+            }
+            for (ComponentService service : component.getServices()) {
+                deactivate((RuntimeComponent) component,
+                        (RuntimeComponentService) service);
+            }
+
+            for (ComponentReference reference : component.getReferences()) {
+                deactivate((RuntimeComponent) component,
+                        (RuntimeComponentReference) reference);
+            }
+
+            Implementation implementation = component.getImplementation();
+            if (implementation instanceof Composite) {
+                deactivate((Composite) implementation);
+            } else if (implementation != null) {
+                removeImplementationProvider((RuntimeComponent) component);
+                removeScopeContainer(component);
+            }
+        } catch (Exception e) {
+            throw new ActivationException(e);
+        }
+    }    
 
     public void activate(Composite composite) throws ActivationException {
         try {
@@ -891,5 +963,5 @@
     public ConversationManager getConversationManager() {
         return conversationManager;
     }
-
+    
 }



---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to