Package aleph.dir

Examples of aleph.dir.DirectoryManager


    }
    return balance;
  }
 
  public static void transfer(String accountNum1, String accountNum2, int amount){
    DirectoryManager locator = HyFlow.getLocator();
    _BankAccount account1 = (_BankAccount) locator.open(accountNum1);
    _BankAccount account2 = (_BankAccount) locator.open(accountNum2);
   
    for(int i=0; i<Benchmark.calls; i++)
      account1.withdraw(amount);
   
    try {
View Full Code Here


    } catch (InterruptedException e) {
      e.printStackTrace();
    }
   
    long balance = 0;
    DirectoryManager locator = HyFlow.getLocator();
    int node = Network.getInstance().nodesCount();
    for(int i=0; i<localObjectsCount; i++){
      for(int j=0;j<node;j++){
        if(i%node==j){
          try {
            balance+=((BankAccount) locator.open(j + "-" + i,"r")).checkBalance();
          } catch (Throwable e) {
            e.printStackTrace();
         
        }
      }
View Full Code Here

    return amount;
  }
 
  @Atomic
  public static long totalBalance(String accountNum1, String accountNum2){
    DirectoryManager locator = HyFlow.getLocator();
    BankAccount account1 = (BankAccount) locator.open(accountNum1);
    BankAccount account2 = (BankAccount) locator.open(accountNum2);
   
    long balance = 0;
    for(int i=0; i<Benchmark.calls; i++)
      balance += account1.checkBalance();
   
View Full Code Here

    new Node(HEAD, -1)// create the head node
  }

  @Atomic
  public void add(Integer value){
    DirectoryManager locator = HyFlow.getLocator();
    Node head = (Node)locator.open(HEAD);
    String oldNext = head.getNext();
    String newNodeId =  Network.getInstance().getID() + "-" + Math.random()// generate random id
    Node newNode = new Node(newNodeId, value);
    newNode.setNext(oldNext);
    head.setNext(newNodeId);
View Full Code Here

    }
    return balance;
  }
 
  public static void transfer(String accountNum1, String accountNum2, int amount){
    DirectoryManager locator = HyFlow.getLocator();
    BankAccount account1 = (BankAccount) locator.open(accountNum1);
    BankAccount account2 = (BankAccount) locator.open(accountNum2);
   
    for(int i=0; i<Benchmark.calls; i++)
      account1.withdraw(amount);
   
    try {
View Full Code Here

    head.setNext(newNodeId);
  }

  @Atomic
  public boolean delete(Integer value){
    DirectoryManager locator = HyFlow.getLocator();
    String next = HEAD;
    String prev = null;
    do// find the last node
      Node node = (Node)locator.open(next, "r");
      if(value.equals(node.getValue())){
        Node deletedNode = (Node)locator.open(next)//reopen for write to be deleted
        Node prevNode = (Node)locator.open(prev);    //open previous node for write
        prevNode.setNext(deletedNode.getNext());
        locator.delete(deletedNode);
        System.out.println("<" + node.getId() + "> " + node.getValue() + "  DELETED....");
        return true;
      }
      prev = next;
      next = node.getNext();
View Full Code Here

    } catch (InterruptedException e) {
      e.printStackTrace();
    }
   
    long balance = 0;
    DirectoryManager locator = HyFlow.getLocator();
    int node = Network.getInstance().nodesCount();
    for(int i=0; i<localObjectsCount; i++){
      for(int j=0;j<node;j++){
        if(i%node==j){
          try {
            System.err.println("Balance = " + balance);
            balance+=((BankAccount) locator.open(j + "-" + i,"r")).checkBalance();
          } catch (Throwable e) {
            e.printStackTrace();
         
        }
      }
View Full Code Here

    return false;
  }

  @Atomic
  public boolean find(Integer value){
    DirectoryManager locator = HyFlow.getLocator();
    String next = HEAD;
    do// find the last node
      Node node = (Node)locator.open(next, "r");
      if(value.equals(node.getValue())){
        System.out.println("Found!");
        return true;
      }
      next = node.getNext();
View Full Code Here

    return false;
  }
 
  @Atomic
  public int sum(){
    DirectoryManager locator = HyFlow.getLocator();
    String next = HEAD;
    int sum = 1// to avoid -1 value of head sentential node
    do// find the last node
      Node node = (Node)locator.open(next, "r");
      next = node.getNext();
      sum += node.getValue();
    }while(next!=null);
    return sum;
  }
View Full Code Here

    }
    throw new TransactionException("Failed to commit the transaction in the defined retries.");
  }
  public void add(Integer value, Context __transactionContext__){
    try{
      DirectoryManager locator = HyFlow.getLocator();
      Node head = (Node)locator.open(HEAD);
      String oldNext = head.getNext(__transactionContext__);
      String newNodeId =  Network.getInstance().getID() + "-" + Math.random()// generate random id
      System.out.println(newNodeId);
      Node newNode = new Node(newNodeId, value);
      newNode.setNext(oldNext, __transactionContext__);
View Full Code Here

TOP

Related Classes of aleph.dir.DirectoryManager

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.