Hello World Dispatch Demo using Document/Literal Style
======================================================

This demo shows how to use the JAX-WS Dispatch and Provider interfaces. The 
client-side Dispatch instance invokes on an endpoint using a JAX-WS Provider 
implementor. The client sends three different invocations. The first uses the 
SOAPMessage data in MESSAGE mode. The second uses the DOMSource data in MESSAGE 
mode. The third uses the DOMSource in PAYLOAD mode. Each message is constructed 
by reading in the XML files in the src/demo/hwDispatch/client directory.

Please review the README in the samples directory before continuing.


Prerequisite
------------

$SUBSTITUTE_PREREQ$


Building and running the demo using ant
---------------------------------------

From the samples/dispatch_provider directory, use the following commands to 
build and run the demo on either UNIX or Windows:

  ant build
  ant server
  ant client
    
To remove the code generated from the WSDL file and the .class files, run:

  ant clean



Building the demo using wsdl2java and javac
-------------------------------------------

From the samples/dispatch_provider directory, first create the target
directory build/classes and then generate code from the WSDL file.

For UNIX:

  mkdir -p build/classes

  wsdl2java -d build/classes -compile ./wsdl/hello_world.wsdl

For Windows:

  mkdir build\classes
    (You must use backslashes.)

  wsdl2java -d build\classes -compile .\wsdl\hello_world.wsdl
    (Use either forward or backslashes.)

Now compile the client and server applications with the following commands:

For UNIX:  
  
  export CLASSPATH=$CLASSPATH:./build/classes
  javac -d build/classes src/demo/hwDispatch/client/*.java
  javac -d build/classes src/demo/hwDispatch/server/*.java

For Windows:

  set classpath=%classpath%;.\build\classes
  javac -d build\classes src\demo\hwDispatch\client\*.java
  javac -d build\classes src\demo\hwDispatch\server\*.java
  
Finally, copy the resource files into the build/classes directory with the 
commands:

For UNIX:

  cp ./src/demo/hwDispatch/client/*.xml ./build/classes/demo/hwDispatch/client
  cp ./src/demo/hwDispatch/server/*.xml ./build/classes/demo/hwDispatch/server

For Windows:

  copy src\demo\hwDispatch\client\*.xml build\classes\demo\hwDispatch\client
  copy src\demo\hwDispatch\server\*.xml build\classes\demo\hwDispatch\server



Running the demo using java
---------------------------

From the samples/hello_world_dispatch directory run the commands, entered on a
single command line:

For UNIX (you must use forward slashes):

    java -Djava.util.logging.config.file=$$SUBSTITUTE_HOME$/etc/logging.properties
         demo.hwDispatch.server.Server &

    java -Djava.util.logging.config.file=$$SUBSTITUTE_HOME$/etc/logging.properties
         demo.hwDispatch.client.Client ./wsdl/hello_world.wsdl

The server process starts in the background. After running the client, use the 
kill command to terminate the server process.

For Windows (use either forward or backslashes):

  start 
    java -Djava.util.logging.config.file=%$SUBSTITUTE_HOME$%\etc\logging.properties
         demo.hwDispatch.server.Server

    java -Djava.util.logging.config.file=%$SUBSTITUTE_HOME$%\etc\logging.properties
       demo.hwDispatch.client.Client .\wsdl\hello_world.wsdl

A new command windows opens for the server process. After running the
client, terminate the server process by issuing Ctrl-C in its command window.

  