1
0
mirror of https://github.com/wjwwood/serial.git synced 2026-01-22 11:44:53 +08:00
serial/examples/serial_example.cc

124 lines
3.3 KiB
C++
Raw Normal View History

2011-03-16 08:03:54 -05:00
#include <string>
#include <iostream>
2012-01-23 14:23:01 -06:00
#include <stdio.h>
#include <time.h>
#ifdef __MACH__
#include <mach/clock.h>
#include <mach/mach.h>
#endif
2011-03-16 08:03:54 -05:00
2012-01-23 09:54:31 -06:00
#include <boost/thread.hpp>
#include "serial/serial.h"
2011-03-16 08:03:54 -05:00
using std::string;
using std::cout;
using std::endl;
2012-01-23 09:54:31 -06:00
int run(int argc, char **argv)
2011-03-16 08:03:54 -05:00
{
if(argc < 3) {
std::cerr << "Usage: test_serial <serial port address> <baudrate>" << std::endl;
return 0;
}
std::string port(argv[1]);
unsigned long baud = 0;
sscanf(argv[2], "%lu", &baud);
2012-01-23 09:54:31 -06:00
// port, baudrate, timeout in milliseconds
serial::Serial serial(port, baud, 10000);
2011-03-16 08:03:54 -05:00
std::cout << "Is the serial port open?";
if(serial.isOpen())
std::cout << " Yes." << std::endl;
else
std::cout << " No." << std::endl;
int count = 0;
while (count >= 0) {
struct timespec start, end;
double diff;
#ifdef __MACH__ // OS X does not have clock_gettime, use clock_get_time
clock_serv_t cclock;
mach_timespec_t mts;
host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
clock_get_time(cclock, &mts);
mach_port_deallocate(mach_task_self(), cclock);
start.tv_sec = mts.tv_sec;
start.tv_nsec = mts.tv_nsec;
#else
clock_gettime(CLOCK_REALTIME, &start);
#endif
size_t bytes_wrote = serial.write("Testing.\n");
#ifdef __MACH__ // OS X does not have clock_gettime, use clock_get_time
host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
clock_get_time(cclock, &mts);
mach_port_deallocate(mach_task_self(), cclock);
end.tv_sec = mts.tv_sec;
end.tv_nsec = mts.tv_nsec;
#else
clock_gettime(CLOCK_REALTIME, &end);
#endif
end.tv_sec -= start.tv_sec;
end.tv_nsec -= start.tv_nsec;
printf("write: %05lu.%09lu\n", end.tv_sec, end.tv_nsec);
#ifdef __MACH__ // OS X does not have clock_gettime, use clock_get_time
host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
clock_get_time(cclock, &mts);
mach_port_deallocate(mach_task_self(), cclock);
start.tv_sec = mts.tv_sec;
start.tv_nsec = mts.tv_nsec;
#else
clock_gettime(CLOCK_REALTIME, &start);
#endif
std::string result = serial.readline();
#ifdef __MACH__ // OS X does not have clock_gettime, use clock_get_time
host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
clock_get_time(cclock, &mts);
mach_port_deallocate(mach_task_self(), cclock);
end.tv_sec = mts.tv_sec;
end.tv_nsec = mts.tv_nsec;
#else
clock_gettime(CLOCK_REALTIME, &end);
#endif
end.tv_sec -= start.tv_sec;
end.tv_nsec -= start.tv_nsec;
printf("read: %05lu.%09lu\n", end.tv_sec, end.tv_nsec);
if (result == string("Testing.\n")) {
}
else {
2012-01-23 09:54:31 -06:00
std::cout << ">" << count << ">" << bytes_wrote << ">";
std::cout << result.length() << "<" << result << std::endl;
cout << "No" << endl;
}
count += 1;
boost::this_thread::sleep(boost::posix_time::milliseconds(100));
2011-03-16 08:03:54 -05:00
}
return 0;
2011-03-18 19:02:32 -05:00
}
2012-01-23 09:54:31 -06:00
int main(int argc, char **argv) {
// try {
2012-01-23 09:54:31 -06:00
return run(argc, argv);
// } catch (std::exception &e) {
// std::cerr << "Unhandled Exception: " << e.what() << std::endl;
// }
2012-01-23 09:54:31 -06:00
}