summaryrefslogtreecommitdiff
path: root/ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp')
-rw-r--r--ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp69
1 files changed, 69 insertions, 0 deletions
diff --git a/ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp b/ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp
new file mode 100644
index 00000000000..348db5e27e7
--- /dev/null
+++ b/ACE/examples/IPC_SAP/DEV_SAP/reader/reader.cpp
@@ -0,0 +1,69 @@
+// $Id$
+
+#include "ace/DEV_Addr.h"
+#include "ace/DEV_Connector.h"
+#include "ace/TTY_IO.h"
+
+ACE_RCSID(reader, reader, "$Id$")
+
+int ACE_TMAIN (int argc, ACE_TCHAR *argv[])
+{
+ if (argc < 2)
+ ACE_ERROR_RETURN ((LM_ERROR,
+ ACE_TEXT ("usage: %s device-filename\n"),
+ argv[0]),
+ 1);
+
+ ACE_TTY_IO read_dev;
+ ACE_DEV_Connector con;
+
+ if (con.connect (read_dev,
+ ACE_DEV_Addr (argv[1])) == -1)
+ ACE_ERROR_RETURN ((LM_ERROR,
+ ACE_TEXT ("%p\n"),
+ argv[1]),
+ 1);
+
+ ACE_TTY_IO::Serial_Params myparams;
+ myparams.baudrate = 9600;
+ myparams.xonlim = 0;
+ myparams.xofflim = 0;
+ myparams.readmincharacters = 0;
+ myparams.readtimeoutmsec = 10000;
+ myparams.paritymode = "EVEN";
+ myparams.ctsenb = false;
+ myparams.rtsenb = 0;
+ myparams.xinenb = false;
+ myparams.xoutenb = false;
+ myparams.modem = false;
+ myparams.rcvenb = true;
+ myparams.dsrenb = false;
+ myparams.dtrdisable = false;
+ myparams.databits = 8;
+ myparams.stopbits = 1;
+
+ if (read_dev.control (ACE_TTY_IO::SETPARAMS,
+ &myparams) == -1)
+ ACE_ERROR_RETURN ((LM_ERROR,
+ ACE_TEXT ("%p control\n"),
+ argv[1]),
+ 1);
+
+ // Read till character 'q'.
+ for (char readback = 'x'; readback != 'q'; )
+ {
+ ssize_t bytes_read =
+ read_dev.recv ((void *) &readback, 1);
+
+ if (bytes_read == 1)
+ ACE_DEBUG ((LM_DEBUG,
+ ACE_TEXT ("read: %c\n"),
+ readback));
+ else if (bytes_read == -1)
+ ACE_ERROR_RETURN ((LM_ERROR,
+ ACE_TEXT ("%p recv\n"),
+ argv[1]), 1);
+ }
+
+ return 0;
+}