summaryrefslogtreecommitdiff
path: root/trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp')
-rw-r--r--trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp48
1 files changed, 48 insertions, 0 deletions
diff --git a/trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp b/trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp
new file mode 100644
index 00000000000..ad0ee029dbd
--- /dev/null
+++ b/trunk/ACE/examples/IPC_SAP/SPIPE_SAP/client.cpp
@@ -0,0 +1,48 @@
+// $Id$
+
+#include "ace/OS_main.h"
+#include "ace/SPIPE_Addr.h"
+#include "ace/SPIPE_Connector.h"
+#include "ace/Log_Msg.h"
+#include "ace/OS_NS_stdio.h"
+#include "ace/OS_NS_string.h"
+
+ACE_RCSID(SPIPE_SAP, client, "$Id$")
+
+#if defined (ACE_HAS_STREAM_PIPES)
+
+#include "shared.h"
+
+int
+ACE_TMAIN (int argc, ACE_TCHAR *argv[])
+{
+ if (argc < 2)
+ ACE_ERROR_RETURN ((LM_ERROR, "usage: %s string [rendezvous]\n", argv[0]), 1);
+
+ if (argc > 2)
+ rendezvous = argv[2];
+
+ ACE_SPIPE_Stream cli_stream;
+ ACE_SPIPE_Connector con;
+
+ if (con.connect (cli_stream, ACE_SPIPE_Addr (rendezvous)) == -1)
+ ACE_ERROR_RETURN ((LM_ERROR, "%p\n", rendezvous), 1);
+
+ ssize_t len = ACE_OS::strlen (argv[1]) + 1;
+
+ if (cli_stream.send (argv[1], len) != len)
+ ACE_ERROR_RETURN ((LM_ERROR, "%p\n", "send"), 1);
+
+ if (cli_stream.close () == -1)
+ ACE_ERROR_RETURN ((LM_ERROR, "%p\n", "close"), 1);
+
+ return 0;
+}
+#else
+#include <stdio.h>
+int ACE_TMAIN (int, ACE_TCHAR *[])
+{
+ ACE_OS::fprintf (stderr, "This feature is not supported\n");
+ return 0;
+}
+#endif /* ACE_HAS_STREAM_PIPES */