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.replication.recovery;
 
 
 import java.io.File;
 import java.util.List;

Created by The eXo Platform SAS.

Author(s):
Alex Reshetnyak
Version:
$Id: WaitConfirmation.java 34445 2009-07-24 07:51:18Z dkatayev $
 
 
 public class WaitConfirmation extends Thread
 {
   
The apache logger.
 
    private static Log log = ExoLogger.getLogger("exo.jcr.component.ext.WaitConfirmation");

   
The wait timeout.
 
    private long timeOut;

   
The RecoveryManager will be saved the ChangesLog.
 
    private RecoveryManager recoveryManager;

   
The identifier string to ChangesLog.
 
    private String identifier;

   
WaitConfirmation constructor.

Parameters:
timeOut the wait timeout
recoveryManager the RecoveryManager
identifier the identifier to ChangesLog
 
    WaitConfirmation(long timeOutRecoveryManager recoveryManagerString identifier)
    {
       super("WaitConfirmation " + identifier);
       this. = timeOut;
       this. = recoveryManager;
       this. = identifier;
 
       if (.isDebugEnabled())
          .debug("init : " + identifier);
    }

   
 
    public void run()
    {
       try
       {
          if (.isDebugEnabled())
             .debug("Before : getParticipantsClusterList().size():"
 
          Thread.sleep();
 
          PendingConfirmationChengesLog confirmationChengesLog =
 
          List<StringnotConfirmationList = new ArrayList<String>(.getParticipantsClusterList());
          notConfirmationList.removeAll(confirmationChengesLog.getConfirmationList());
 
          if (notConfirmationList.size() > 0)
         {
            confirmationChengesLog.setNotConfirmationList(notConfirmationList);
            String fileName = .save();
            if (.isDebugEnabled())
               .debug("save : " + );
            for (String ownerName : confirmationChengesLog.getConfirmationList())
               .removeChangesLog(ownerName);
         }
         else if (notConfirmationList.size() == 0 && confirmationChengesLog.getDataFilePath() != null)
         {
            .removeDataFile(new File(confirmationChengesLog.getDataFilePath()));
         }
         if (.isDebugEnabled())
            .debug("After : getParticipantsClusterList().size():"
               + confirmationChengesLog.getConfirmationList().size());
         if (.isDebugEnabled())
            .debug("remove : " + );
      }
      catch (InterruptedException e)
      {
         .error("Can't save ChangesLog"e);
      }
      catch (FileNotFoundException e)
      {
         .error("Can't save ChangesLog"e);
      }
      catch (IOException e)
      {
         .error("Can't save ChangesLog"e);
      }
      catch (Exception e)
      {
         .error("Can't save ChangesLog"e);
      }
   }
New to GrepCode? Check out our FAQ X