All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.db4o.ReplicationRecord Maven / Gradle / Ivy

The newest version!
/* Copyright (C) 2004 - 2005  db4objects Inc.  http://www.db4o.com

This file is part of the db4o open source object database.

db4o is free software; you can redistribute it and/or modify it under
the terms of version 2 of the GNU General Public License as published
by the Free Software Foundation and as clarified by db4objects' GPL 
interpretation policy, available at
http://www.db4o.com/about/company/legalpolicies/gplinterpretation/
Alternatively you can write to db4objects, Inc., 1900 S Norfolk Street,
Suite 350, San Mateo, CA 94403, USA.

db4o 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 General Public License
for more details.

You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */
package com.db4o;

import com.db4o.ext.*;
import com.db4o.query.*;

/**
 * tracks the version of the last replication between
 * two Objectcontainers.
 * 
 */
public class ReplicationRecord implements Internal4{
   
    public Db4oDatabase _youngerPeer;
    public Db4oDatabase _olderPeer;
    public long _version;
    
    public ReplicationRecord(){
    }
    
    public ReplicationRecord(Db4oDatabase younger, Db4oDatabase older){
        _youngerPeer = younger;
        _olderPeer = older;
    }
    
    public void setVersion(long version){
        _version = version;
    }
    
    public void store(YapStream stream){
        stream.showInternalClasses(true);
        Transaction ta = stream.checkTransaction(null);
        stream.setAfterReplication(ta, this, 1, false);
        stream.commit();
        stream.showInternalClasses(false);
    }
    
    public static ReplicationRecord beginReplication(Transaction transA, Transaction  transB){
        
        YapStream peerA = transA.i_stream;
        YapStream peerB = transB.i_stream;
        
        Db4oDatabase dbA = peerA.identity();
        Db4oDatabase dbB = peerB.identity();
        
        dbB.bind(transA);
        dbA.bind(transB);
        
        Db4oDatabase younger = null;
        Db4oDatabase older = null;
        
        if(dbA.isOlderThan(dbB)){
            younger = dbB;
            older = dbA;
        }else{
            younger = dbA;
            older = dbB;
        }
        
        ReplicationRecord rrA = queryForReplicationRecord(peerA, younger, older);
        ReplicationRecord rrB = queryForReplicationRecord(peerB, younger, older);
        if(rrA == null){
            if(rrB == null){
                return new ReplicationRecord(younger, older);
            }
            rrB.store(peerA);
            return rrB;
        }
        
        if(rrB == null){
            rrA.store(peerB);
            return rrA;
        }
        
        if(rrA != rrB){
            peerB.showInternalClasses(true);
            int id = peerB.getID1(transB, rrB);
            peerB.bind1(transB, rrA, id);
            peerB.showInternalClasses(false);
        }
        
        return rrA;
    }
    
    public static ReplicationRecord queryForReplicationRecord(YapStream stream, Db4oDatabase younger, Db4oDatabase older) {
        ReplicationRecord res = null;
        stream.showInternalClasses(true);
        Query q = stream.querySharpenBug();
        q.constrain(YapConst.CLASS_REPLICATIONRECORD);
        q.descend("_youngerPeer").constrain(younger).identity();
        q.descend("_olderPeer").constrain(older).identity();
        ObjectSet objectSet = q.execute();
        if(objectSet.hasNext()){
            res = (ReplicationRecord)objectSet.next();
        }
        stream.showInternalClasses(false);
        return res;
    }
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy