01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: *
15: * See the License for the specific language governing permissions and
16: * limitations under the License.
17: */
18:
19: /**
20: * @author Aleksander V. Budniy
21: * @version $Revision: 1.3 $
22: */
23:
24: /**
25: * Created on 31.01.2005
26: */package org.apache.harmony.jpda.tests.jdwp.MultiSession;
27:
28: import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
29: import org.apache.harmony.jpda.tests.share.SyncDebuggee;
30:
31: /**
32: * This class provides simple HelloWorld debuggee class used sync connection.
33: */
34: public class MultiSessionDebuggee extends SyncDebuggee {
35:
36: public void run() {
37: logWriter.println("Debuggee is started");
38: synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
39: synchronizer
40: .receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
41: logWriter.println("FROM DEBUGGEE: thread was resumed");
42: synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
43: printWord();
44: synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
45:
46: logWriter
47: .println("-> MultiSessionDebuggee: wait for signal to continue...");
48: while (true) {
49: if (synchronizer
50: .receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE)) {
51: logWriter
52: .println("-> MultiSessionDebuggee: signal received!");
53: break;
54: }
55: }
56:
57: logWriter.println("-> MultiSessionDebuggee: FINISH...");
58: }
59:
60: public void printWord() {
61: logWriter.println("Hello World ---- ");
62: }
63:
64: public static void main(String[] args) {
65: runDebuggee(MultiSessionDebuggee.class);
66: }
67: }
|