Author: cziegeler
Date: Thu Feb  9 11:02:27 2012
New Revision: 1242275

URL: http://svn.apache.org/viewvc?rev=1242275&view=rev
Log:
SLING-2409 : If configuration is removed by config admin, state of provided 
artifact should either be uninstalled or ignored

Modified:
    
sling/trunk/installer/core/src/main/java/org/apache/sling/installer/core/impl/OsgiInstallerImpl.java

Modified: 
sling/trunk/installer/core/src/main/java/org/apache/sling/installer/core/impl/OsgiInstallerImpl.java
URL: 
http://svn.apache.org/viewvc/sling/trunk/installer/core/src/main/java/org/apache/sling/installer/core/impl/OsgiInstallerImpl.java?rev=1242275&r1=1242274&r2=1242275&view=diff
==============================================================================
--- 
sling/trunk/installer/core/src/main/java/org/apache/sling/installer/core/impl/OsgiInstallerImpl.java
 (original)
+++ 
sling/trunk/installer/core/src/main/java/org/apache/sling/installer/core/impl/OsgiInstallerImpl.java
 Thu Feb  9 11:02:27 2012
@@ -900,7 +900,14 @@ public class OsgiInstallerImpl
                 key = resourceType + ':' + resourceId;
                 final TaskResource tr = erl.getFirstResource();
                 if ( tr != null ) {
-                    if ( tr.getState() != ResourceState.IGNORED ) {
+                    if ( tr.getState() == ResourceState.IGNORED ) {
+                        // if it has been ignored before, we activate it now 
again!
+                        
((RegisteredResourceImpl)tr).setState(ResourceState.INSTALL);
+                        this.persistentList.save();
+                        this.scheduleRetry();
+                    } else if ( tr.getState() == ResourceState.UNINSTALLED ) {
+                        // it has already been removed - nothing do to
+                    } else {
                         final UpdateHandler handler = 
this.findHandler(tr.getScheme());
                         if ( handler == null ) {
                             // set to ignored
@@ -919,12 +926,9 @@ public class OsgiInstallerImpl
                                 
((RegisteredResourceImpl)tr).setState(ResourceState.IGNORED);
                             }
                         }
-                    } else {
-                        // if it has been ignored before, we activate it now 
again!
-                        
((RegisteredResourceImpl)tr).setState(ResourceState.INSTALL);
+                        this.persistentList.save();
+                        this.scheduleRetry();
                     }
-                    this.persistentList.save();
-                    this.scheduleRetry();
                 }
             }
         }


Reply via email to