+++ /dev/null
-/* Copyright (c) 2012-2013. The SimGrid Team.
- * All rights reserved. */
-
-/* This program is free software; you can redistribute it and/or modify it
- * under the terms of the license (GNU LGPL) which comes with this package. */
-
-package kademlia;
-
-import java.util.ArrayList;
-import java.util.Collections;
-
-/**
- * Answer to a "FIND_NODE" query. Contains the nodes closest to
- * an id given.
- */
-public class Answer {
- /**
- * Id of the node we're trying to find
- */
- private int destinationId;
- /**
- * Closest nodes in the answer.
- */
- private ArrayList<Contact> nodes;
-
- /**
- * Constructor
- */
- public Answer(int destinationId) {
- this.destinationId = destinationId;
- nodes = new ArrayList<Contact>();
- }
- /**
- * Returns the destination id
- */
- int getDestinationId() {
- return destinationId;
- }
- /**
- * Returns the list of the nodes in the answer
- */
- ArrayList<Contact> getNodes() {
- return nodes;
- }
- /**
- * Returns the answer array size
- */
- int size() {
- return nodes.size();
- }
- /**
- * Remove an element from the answer.
- */
- public void remove(int index) {
- nodes.remove(index);
- }
- /**
- * Add a contact to the answer.
- */
- public void add(Contact contact) {
- nodes.add(contact);
- }
- /**
- * Merge the contents of this answer with another answer
- */
- public int merge(Answer answer) {
- int nbAdded = 0;
-
- for (Contact c: answer.getNodes()) {
- if (!nodes.contains(c)) {
- nbAdded++;
- nodes.add(c);
- }
- }
- Collections.sort(nodes);
- //Trim the list
- while (answer.size() > Common.BUCKET_SIZE) {
- answer.remove(answer.size() - 1);
- }
- return nbAdded;
- }
- /**
- * Returns if the destination has been found
- */
- public boolean destinationFound() {
- if (nodes.size() < 1) {
- return false;
- }
- Contact tail = nodes.get(0);
- return tail.getDistance() == 0;
- }
- @Override
- public String toString() {
- return "Answer [destinationId=" + destinationId + ", nodes=" + nodes
- + "]";
- }
-
-}