]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.detached/src/main/java/org/argeo/slc/detached/drivers/MemoryDriver.java
support.jemmy: PopupMenuActuator added,
[gpl/argeo-slc.git] / runtime / org.argeo.slc.detached / src / main / java / org / argeo / slc / detached / drivers / MemoryDriver.java
index ffae5efda30b843cbec3f8203fbea59407154b16..3d252d6e5d9362731168afcc311241482c4d1ccb 100644 (file)
@@ -5,27 +5,35 @@ import org.argeo.slc.detached.DetachedClient;
 import org.argeo.slc.detached.DetachedRequest;
 
 public class MemoryDriver extends AbstractDriver implements DetachedClient {
+       private DetachedRequest currentRequest = null;
+       private DetachedAnswer currentAnswer = null;
 
        // DRIVER
-       public DetachedRequest receiveRequest() throws Exception {
-               // TODO Auto-generated method stub
-               return null;
+       public synchronized DetachedRequest receiveRequest() throws Exception {
+               while (currentRequest == null)
+                       this.wait(500);
+               return currentRequest;
        }
 
-       public void sendAnswer(DetachedAnswer answer) throws Exception {
-               // TODO Auto-generated method stub
-
+       public synchronized void sendAnswer(DetachedAnswer answer) throws Exception {
+               currentAnswer = answer;
+               this.notify();
        }
 
        // CLIENT
-       public DetachedAnswer receiveAnswer() throws Exception {
-               // TODO Auto-generated method stub
-               return null;
+       public synchronized DetachedAnswer receiveAnswer() throws Exception {
+               while (currentAnswer == null)
+                       this.wait(500);
+               DetachedAnswer answer = currentAnswer;
+               currentAnswer = null;
+               currentRequest = null;
+               return answer;
        }
 
-       public void sendRequest(DetachedRequest request) throws Exception {
-               // TODO Auto-generated method stub
-               
+       public synchronized void sendRequest(DetachedRequest request)
+                       throws Exception {
+               currentRequest = request;
+               this.notify();
        }
 
 }