Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright (C) 2009 eXo Platform SAS.
   *
   * This is free software; you can redistribute it and/or modify it
   * under the terms of the GNU Lesser General Public License as
   * published by the Free Software Foundation; either version 2.1 of
   * the License, or (at your option) any later version.
   *
   * This software is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this software; if not, write to the Free
  * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  */
 package org.exoplatform.services.jcr.ext.backup.impl;
 
 
 import java.net.URL;
 import java.util.List;
Created by The eXo Platform SARL .

Author(s):
Gennady Azarenkov
Version:
$Id: $
 
 
 public abstract class AbstractIncrementalBackupJob extends AbstractBackupJob implements ItemsPersistenceListener
 {
 
    private static Log log = ExoLogger.getLogger("exo.jcr.component.ext.IncrementalBackupJob");

   
Should be synchronized collection.
 
    protected final List<ItemStateChangesLogsuspendBuffer;

   
The amount of current working threads.
 
    protected AtomicInteger workingThreads = new AtomicInteger();

   
Allows to make all threads waiting.
 
    protected CountDownLatch latcher = null;
 
    {
       this. = Collections.synchronizedList(new ArrayList<ItemStateChangesLog>());
       this. = 1;
 
       notifyListeners();
    }
 
    public final int getType()
    {
       return ;
    }

   
 
    public void onSaveItems(ItemStateChangesLog chlog)
    {
       if ( == )
       {
          return;
       }
       else if ( == )
       {
          .add(chlog);
       }
       else if ( == )
       {
          try
          {
             // wait while suspended buffer is not clear
             if ( != null && .getCount() != 0)
             {
                .await();
             }
 
             .incrementAndGet();
 
            save(chlog);
            .decrementAndGet();
         }
         catch (IOException e)
         {
            .error("Incremental backup: Can't save log "e);
            notifyError("Incremental backup: Can't save log "e);
         }
         catch (InterruptedException e)
         {
            .error("Incremental backup: Can't save log "e);
            notifyError("Incremental backup: Can't save log "e);
         }
      }
   }

   
   public final void run()
   {
       = ;
      notifyListeners();
   }
   public final void suspend()
   {
       = ;
      ++;
      notifyListeners();
   }
   public final URL resume()
   {
      try
      {
         // waiting until all current working threads finished
         while (.get() != 0)
         {
            try
            {
               Thread.sleep(50);
            }
            catch (InterruptedException e)
            {
               throw new SuspendException(e);
            }
         }
         // nobody write into storage (all threads add changes logs to suspendBuffer), so create new one
          = createStorage();
         //  make all threads wait on save, that allow flush suspendBuffer
          = new CountDownLatch(1);
          = ;
         for (ItemStateChangesLog log : )
         {
            save(log);
         }
         if (.getIncrementalJobNumber() != 0 &&  == .getIncrementalJobNumber() + 1)
         {
             = ;
         }
      }
      catch (Throwable e)
      {
         .error("Incremental backup: resume failed "e);
         notifyError("Incremental backup: resume failed "e);
      }
      finally
      {
         // all threads now continue their work
         .clear();
         .countDown();
      }
      notifyListeners();
      return ;
   }

   
Implementation specific saving

Parameters:
log
   protected abstract void save(ItemStateChangesLog logthrows IOException;
New to GrepCode? Check out our FAQ X