# HG changeset patch
# User mir3636
# Date 1470218951 -32400
# Node ID f7210f8344037b01e32225d9568f3d00d922847e
# Parent  3332879d1bd0e2fbf49b23fd1fe83b5df5b29d5a
add unique node id

diff -r 3332879d1bd0 -r f7210f834403 src/main/java/jp/ac/u_ryukyu/treevnc/TreeManagement.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeManagement.java	Fri Jul 29 16:03:51 2016 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeManagement.java	Wed Aug 03 19:09:11 2016 +0900
@@ -171,7 +171,7 @@
 
     public void connectTo(TreeVNCNode newparent, TreeVNCNode n) throws IOException {
         TreeVncProtocol vc1 = new TreeVncProtocol(n.getHostname(),n.getPort());
-            short nodeId = (short) ( n.getTreeNum() + ( treeId << 12 ));
+            short nodeId = (short) n.getId();
             vc1.connectTo(newparent.getHostname(), newparent.getPort(), isLeader(n), nodeId);
     }
 
@@ -191,10 +191,12 @@
      * Determine tree topology and send CONNECT_TO command
      * @param hostname
      * @param port
+     * @param id
      */
-    public void decideWhereToConnect(String hostname, int port, String localhostname) {
+    public void decideWhereToConnect(String hostname, int port, String localhostname, int id) {
         TreeVNCNode node = new TreeVNCNode(hostname, port, localhostname);
         node.setTreeNum(nodeList.size());
+        node.setId(id);
 
         InetAddress ipAddress = null;
         try {
diff -r 3332879d1bd0 -r f7210f834403 src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java	Fri Jul 29 16:03:51 2016 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java	Wed Aug 03 19:09:11 2016 +0900
@@ -70,6 +70,7 @@
     private DatagramSocket socket = null;
     private byte[] originalInitData = null;
     private boolean childrenMulticast = true;
+    private int uniqueNodeId = 0; // uniquenodeid in all trees
 
     public TreeRFBProto(boolean isTreeManager, ViewerInterface viewer) {
         nets.setMyRfb(this);
@@ -754,6 +755,10 @@
         return treeManager;
     }
 
+    public int getNewNodeId () {
+        return uniqueNodeId++;
+    }
+
     /**
      * change VNCServer is called when host change.
      *
diff -r 3332879d1bd0 -r f7210f834403 src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNetwork.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNetwork.java	Fri Jul 29 16:03:51 2016 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNetwork.java	Wed Aug 03 19:09:11 2016 +0900
@@ -12,7 +12,6 @@
 
 public class TreeVNCNetwork {
 
-    
     private HashMap<String, TreeManagement> interfaces = new HashMap<String, TreeManagement>();
     private TreeRFBProto myRfb;
     private boolean useHostName = false;
@@ -96,5 +95,4 @@
 	}
 
 	
-	
 }
diff -r 3332879d1bd0 -r f7210f834403 src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNode.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNode.java	Fri Jul 29 16:03:51 2016 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVNCNode.java	Wed Aug 03 19:09:11 2016 +0900
@@ -3,7 +3,8 @@
 public class TreeVNCNode {
     String hostname;
     int port;
-    int treeNum;
+    int treeNum; //tree position
+    int id;      //unique node id in all trees
     String localhostname;
 
     public TreeVNCNode(String hostname, int port, String localhostname) {
@@ -36,5 +37,11 @@
 		hostname = localhostname;
 	}
 
+    public int getId() {
+        return id;
+    }
 
+    public void setId(int id) {
+        this.id = id;
+    }
 }
diff -r 3332879d1bd0 -r f7210f834403 src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java	Fri Jul 29 16:03:51 2016 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java	Wed Aug 03 19:09:11 2016 +0900
@@ -88,7 +88,8 @@
      * @param myHostName 
      */
     void handleWhereToConnect(int port, String hostname, String myHostName) {
-        rfb.getTreeManager(intf).decideWhereToConnect(hostname,port,myHostName);
+        int id = rfb.getNewNodeId();
+        rfb.getTreeManager(intf).decideWhereToConnect(hostname,port,myHostName,id);
     }
 
     /**