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

Testing my changes to make sure they are consistant.

This commit is contained in:
John Harrison 2012-01-30 16:33:58 -06:00
parent 119be4630e
commit f7cee5e175
4 changed files with 85 additions and 6 deletions

View File

@ -1,11 +1,21 @@
#include <string>
#include <iostream>
#include <stdio.h>
#include <time.h>
#ifdef __MACH__
#include <mach/clock.h>
#include <mach/mach.h>
#endif
#include <boost/thread.hpp>
#include "serial/serial.h"
using std::string;
using std::cout;
using std::endl;
int run(int argc, char **argv)
{
if(argc < 3) {
@ -18,7 +28,7 @@ int run(int argc, char **argv)
sscanf(argv[2], "%lu", &baud);
// port, baudrate, timeout in milliseconds
serial::Serial serial(port, baud, 30000);
serial::Serial serial(port, baud, 10000);
std::cout << "Is the serial port open?";
if(serial.isOpen())
@ -28,10 +38,74 @@ int run(int argc, char **argv)
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 {
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));

View File

@ -15,7 +15,7 @@ IF(EXISTS /usr/bin/clang)
set(CMAKE_CXX_COMPILER /usr/bin/clang++)
set(CMAKE_OSX_DEPLOYMENT_TARGET "")
# set(CMAKE_CXX_FLAGS "-ferror-limit=5 -std=c++0x -stdlib=libc++")
set(CMAKE_CXX_FLAGS "-ferror-limit=5 -O3 -Wall -Weffc++ -pedantic -pedantic-errors -Wextra -Wall -Waggregate-return -Wcast-align -Wcast-qual -Wchar-subscripts -Wcomment -Wconversion -Wdisabled-optimization -Wfloat-equal -Wformat -Wformat=2 -Wformat-nonliteral -Wformat-security -Wformat-y2k -Wimplicit -Wimport -Winit-self -Winline -Winvalid-pch -Wlong-long -Wmissing-braces -Wmissing-field-initializers -Wmissing-format-attribute -Wmissing-include-dirs -Wmissing-noreturn -Wpacked -Wparentheses -Wpointer-arith -Wredundant-decls -Wreturn-type -Wsequence-point -Wshadow -Wsign-compare -Wstack-protector -Wstrict-aliasing -Wstrict-aliasing=2 -Wswitch -Wswitch-default -Wswitch-enum -Wtrigraphs -Wuninitialized -Wunknown-pragmas -Wunreachable-code -Wunused -Wunused-function -Wunused-label -Wunused-parameter -Wunused-value -Wunused-variable -Wvariadic-macros -Wvolatile-register-var -Wwrite-strings")
set(CMAKE_CXX_FLAGS "-ferror-limit=5 -Wall -Weffc++ -pedantic -pedantic-errors -Wextra -Wall -Waggregate-return -Wcast-align -Wcast-qual -Wchar-subscripts -Wcomment -Wconversion -Wdisabled-optimization -Wfloat-equal -Wformat -Wformat=2 -Wformat-nonliteral -Wformat-security -Wformat-y2k -Wimplicit -Wimport -Winit-self -Winline -Winvalid-pch -Wlong-long -Wmissing-braces -Wmissing-field-initializers -Wmissing-format-attribute -Wmissing-include-dirs -Wmissing-noreturn -Wpacked -Wparentheses -Wpointer-arith -Wredundant-decls -Wreturn-type -Wsequence-point -Wshadow -Wsign-compare -Wstack-protector -Wstrict-aliasing -Wstrict-aliasing=2 -Wswitch -Wswitch-default -Wswitch-enum -Wtrigraphs -Wuninitialized -Wunknown-pragmas -Wunreachable-code -Wunused -Wunused-function -Wunused-label -Wunused-parameter -Wunused-value -Wunused-variable -Wvariadic-macros -Wvolatile-register-var -Wwrite-strings")
set(CMAKE_BUILD_TYPE Debug)
ENDIF(EXISTS /usr/bin/clang)

View File

@ -368,8 +368,11 @@ Serial::SerialImpl::read (char* buf, size_t size)
}
fd_set readfds;
ssize_t bytes_read = 0;
int count = 0;
while (true)
{
count++;
// printf("Counting: %u\n", count);
if (timeout_ != -1)
{
FD_ZERO (&readfds);

View File

@ -89,8 +89,10 @@ Serial::read (size_t size)
string result (read_cache_.substr (0, size));
read_cache_.clear ();
int count = 0;
while (true)
{
// printf("%u\n", count++);
char buf[256];
size_t chars_read = pimpl_->read (buf, 256);
if (chars_read > 0)