/*
* Galaxy
* Copyright (c) 2012-2014, Parallel Universe Software Co. All rights reserved.
*
* This program and the accompanying materials are dual-licensed under
* either the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation
*
* or (per the licensee's choosing)
*
* under the terms of the GNU Lesser General Public License version 3.0
* as published by the Free Software Foundation.
*/
package co.paralleluniverse.galaxy.core;
import co.paralleluniverse.galaxy.core.Message.BACKUP;
import java.util.Iterator;
/**
*
* @author pron
*/
public interface Backup {
void setCache(Cache cache);
boolean startBackup();
/**
* Must be called by the cache when the line is synchronized, and under a read-lock (i.e. between startBackup and endBackup)
*
* @param id
* @param version
*/
void backup(long id, long version);
void endBackup(boolean locked);
boolean inv(long id, short owner);
void flush();
Iterator<BACKUP> iterOwned();
void receive(Message message);
void slavesAck(long id);
void slavesInvAck(long id);
}