diff options
author | Josh Blum <josh@joshknows.com> | 2010-07-12 20:39:21 -0700 |
---|---|---|
committer | Josh Blum <josh@joshknows.com> | 2010-07-12 20:39:21 -0700 |
commit | 508af598a1b32345a53522b4d6d71e021f448347 (patch) | |
tree | 8399f1b3ba955b5dc2228fc818d131ce11a78c56 /host/examples/rx_timed_samples.cpp | |
parent | 4594aef53f75be451b9b64ad0ebdfdc742df251c (diff) | |
download | uhd-508af598a1b32345a53522b4d6d71e021f448347.tar.gz uhd-508af598a1b32345a53522b4d6d71e021f448347.tar.bz2 uhd-508af598a1b32345a53522b4d6d71e021f448347.zip |
uhd: switch statements to handle error code, default md to error code none
Diffstat (limited to 'host/examples/rx_timed_samples.cpp')
-rw-r--r-- | host/examples/rx_timed_samples.cpp | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/host/examples/rx_timed_samples.cpp b/host/examples/rx_timed_samples.cpp index 95f805007..3b9acbb2c 100644 --- a/host/examples/rx_timed_samples.cpp +++ b/host/examples/rx_timed_samples.cpp @@ -92,20 +92,32 @@ int UHD_SAFE_MAIN(int argc, char *argv[]){ uhd::io_type_t::COMPLEX_FLOAT32, uhd::device::RECV_MODE_ONE_PACKET ); - if (num_rx_samps == 0 and num_acc_samps > 0){ + + //handle the error codes + switch(md.error_code){ + case uhd::rx_metadata_t::ERROR_CODE_NONE: + break; + + case uhd::rx_metadata_t::ERROR_CODE_TIMEOUT: + if (num_acc_samps == 0) continue; std::cout << boost::format( - "Got error code 0x%x before all samples received, possible packet loss, exiting loop..." + "Got timeout before all samples received, possible packet loss, exiting loop..." ) % md.error_code << std::endl; - break; + goto done_loop; + + default: + std::cout << boost::format( + "Got error code 0x%x, exiting loop..." + ) % md.error_code << std::endl; + goto done_loop; } - if (num_rx_samps == 0) continue; //wait for packets with contents if(verbose) std::cout << boost::format( "Got packet: %u samples, %u full secs, %f frac secs" ) % num_rx_samps % md.time_spec.get_full_secs() % md.time_spec.get_frac_secs() << std::endl; num_acc_samps += num_rx_samps; - } + } done_loop: //finished std::cout << std::endl << "Done!" << std::endl << std::endl; |