samples/deadlock/src/org/apidesign/deadlock/startuplock/CLIHandlerBlocking.java
author Jaroslav Tulach <jtulach@netbeans.org>
Sat, 14 Jun 2008 09:54:31 +0200
changeset 106 a773f1bc5ba1
child 133 50bf1b976c0d
permissions -rw-r--r--
Racecondition tests
     1 package org.apidesign.deadlock.startuplock;
     2 
     3 import java.io.DataOutputStream;
     4 import java.io.File;
     5 import java.io.FileOutputStream;
     6 import java.io.IOException;
     7 import java.net.ServerSocket;
     8 import java.util.logging.Level;
     9 import java.util.logging.Logger;
    10 
    11 public final class CLIHandlerBlocking {
    12     // BEGIN: cli.real
    13     public static int start(File lockFile) throws IOException {
    14         enterState(10);
    15         if (lockFile.exists ()) {
    16             // read the port number and connect to it
    17             enterState(11);
    18             int alive = readPortNumber(lockFile);
    19             if (alive != -1) {
    20                 // exit
    21                 return alive;
    22             }
    23         }
    24         // otherwise try to create the file yourself
    25         enterState(20);
    26         lockFile.createNewFile();
    27         DataOutputStream os = new DataOutputStream(new FileOutputStream(lockFile));
    28         ServerSocket server = new ServerSocket();
    29         enterState(21);
    30         int p = server.getLocalPort();
    31         enterState(22);
    32         os.writeInt(p);
    33         enterState(23);
    34         
    35         return p;
    36     }
    37     // END: cli.real
    38 
    39     private static Logger LOG = Logger.getLogger(CLIHandlerBlocking.class.getName());
    40     private static void enterState(int state) {
    41         LOG.log(Level.FINEST, "enterState {0}", state);
    42     }
    43 
    44     private static int readPortNumber(File lockFile) throws IOException {
    45         return -1;
    46     }
    47 }