view src/alice/jungle/transaction/NetworkTransactionManager.java @ 41:b8b9668da13c

implemented DistributeApp
author one
date Tue, 09 Jul 2013 17:37:09 +0900
parents 054dc02c117d
children 4419ac56cbfd
line wrap: on
line source

package alice.jungle.transaction;

import java.io.IOException;
import java.util.Iterator;

import alice.jungle.codesegment.LogUpdateCodeSegment;
import alice.jungle.datasegment.store.operations.DefaultTreeOperationLogContainer;

import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeList;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeListWriter;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.Result;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.ChangeSet;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.AtomicReservableReference;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.AtomicReservableReference.Reservation;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultChangeSet;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeContext;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.TransactionManager;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.TreeContext;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultError;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;

public class NetworkTransactionManager<T extends TreeNode<T>> implements TransactionManager<T> 
{

	private final AtomicReservableReference<TreeContext<T>> repository;
	private final TreeContext<T> tip;
	private final ChangeListWriter writer;
	private final String uuid;	
	private final String treeName;	
	
	public NetworkTransactionManager(String _treeName, ChangeListWriter _writer,TreeContext<T> _tip,
			AtomicReservableReference<TreeContext<T>> _repository,String _uuid)
	{
		repository = _repository;
		tip = _tip;
		writer = _writer;
		uuid = _uuid;
		treeName = _treeName;
	}
	
	@Override
	public Either<Error, TransactionManager<T>> commit(T _newRoot,final TreeOperationLog _log) {
		ChangeSet cs = tip.getChangeSet();
		long currentRevision = cs.revision();
		long nextRevision = currentRevision + 1;
		
		ChangeList list = new ChangeList() {
			@Override
			public Iterator<TreeOperation> iterator(){
				return _log.iterator();
			}
		};
		
		Node root = _newRoot.getAsNode();
		DefaultChangeSet newCs = new DefaultChangeSet(root, cs, list, uuid, nextRevision);
		DefaultTreeContext<T> newContext = new DefaultTreeContext<T>(_newRoot,newCs);
		
		@SuppressWarnings("rawtypes")
		Reservation reservation = repository.makeReservation(tip, newContext);
		if(reservation == null) {
			return DefaultEither.newA((Error)new DefaultError());
		}
		Result r = writer.write(list);
		if(r != Result.SUCCESS) {
			return DefaultEither.newA((Error)new DefaultError());
		}
		try {
			updateDataSegment(uuid, treeName, list);
		} catch (IOException e) {
			e.printStackTrace();
		}
		reservation.confirm();
		TransactionManager<T> txManager = new NetworkTransactionManager<T>(treeName, writer, newContext, repository, uuid);
		return DefaultEither.newB(txManager);
	}
	
	private void updateDataSegment(String _uuid, String _treeName, Iterable<TreeOperation> _log) throws IOException {
		DefaultTreeOperationLogContainer container = new DefaultTreeOperationLogContainer();
		container.setTreeName(_treeName);
		container.setUUID(_uuid);
		container.unconvert(_log);
		LogUpdateCodeSegment cs = new LogUpdateCodeSegment();
		cs.ods.update("local", "log", container);
		
	}

	@Override
	public long getRevision() 
	{
		ChangeSet cs = tip.getChangeSet();
		return cs.revision();
	}

	@Override
	public String getUUID() {
		return uuid;
	}

}