diff options
author | stevie <stevie@65a5c917-d112-43f1-993d-58c26a4786be> | 2011-05-29 10:24:15 +0000 |
---|---|---|
committer | stevie <stevie@65a5c917-d112-43f1-993d-58c26a4786be> | 2011-05-29 10:24:15 +0000 |
commit | da6ffc8343221ca66789c2e9c62506e5653301ea (patch) | |
tree | 56bff05ac3c506ff7906583660326c5c076017d9 /blocks/src/lib/abstract_data_unit.cc | |
parent | f76f2bc712353a587782fe11a79b6447c9bbb88a (diff) |
Rename 'decoder' to 'blocks'.
git-svn-id: http://op25.osmocom.org/svn/trunk@283 65a5c917-d112-43f1-993d-58c26a4786be
Diffstat (limited to 'blocks/src/lib/abstract_data_unit.cc')
-rw-r--r-- | blocks/src/lib/abstract_data_unit.cc | 181 |
1 files changed, 181 insertions, 0 deletions
diff --git a/blocks/src/lib/abstract_data_unit.cc b/blocks/src/lib/abstract_data_unit.cc new file mode 100644 index 0000000..fa00cce --- /dev/null +++ b/blocks/src/lib/abstract_data_unit.cc @@ -0,0 +1,181 @@ +/* -*- C++ -*- */ + +/* + * Copyright 2008 Steve Glass + * + * This file is part of OP25. + * + * OP25 is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3, or (at your option) + * any later version. + * + * OP25 is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public + * License for more details. + * + * You should have received a copy of the GNU General Public License + * along with OP25; see the file COPYING. If not, write to the Free + * Software Foundation, Inc., 51 Franklin Street, Boston, MA + * 02110-1301, USA. + */ + +#include <abstract_data_unit.h> + +#include <algorithm> +#include <cstring> +#include <functional> +#include <iomanip> +#include <iostream> +#include <stdexcept> +#include <sstream> +#include <utility> + +using namespace std; + +abstract_data_unit::~abstract_data_unit() +{ +} + +void +abstract_data_unit::correct_errors() +{ + if(is_complete()) { + do_correct_errors(d_frame_body); + } else { + ostringstream msg; + msg << "cannot correct errors - frame is not complete" << endl; + msg << "(size now: " << frame_size() << ", expected size: " << frame_size_max() << ")" << endl; + msg << "func: " << __PRETTY_FUNCTION__ << endl; + msg << "file: " << __FILE__ << endl; + msg << "line: " << __LINE__ << endl; + throw logic_error(msg.str()); + } +} + +void +abstract_data_unit::decode_audio(imbe_decoder& imbe) +{ + if(is_complete()) { + do_decode_audio(d_frame_body, imbe); + } else { + ostringstream msg; + msg << "cannot decode audio - frame is not complete" << endl; + msg << "(size now: " << frame_size() << ", expected size: " << frame_size_max() << ")" << endl; + msg << "func: " << __PRETTY_FUNCTION__ << endl; + msg << "file: " << __FILE__ << endl; + msg << "line: " << __LINE__ << endl; + throw logic_error(msg.str()); + } +} + +size_t +abstract_data_unit::decode_frame(size_t msg_sz, uint8_t *msg) +{ + return decode_frame(d_frame_body, msg_sz, msg); +} + +size_t +abstract_data_unit::decode_frame(const_bit_vector& frame_body, size_t msg_sz, uint8_t *msg) +{ + size_t n = 0; + if(is_complete()) { + if(size() <= msg_sz) { + n = extract(frame_body, 0, static_cast<int>(frame_body.size()), msg); + } else { + ostringstream msg; + msg << "cannot decode frame body "; + msg << "(msg size: " << msg_sz << ", actual size: " << size() << ")" << endl; + msg << "func: " << __PRETTY_FUNCTION__ << endl; + msg << "file: " << __FILE__ << endl; + msg << "line: " << __LINE__ << endl; + throw length_error(msg.str()); + } + } else { + ostringstream msg; + msg << "cannot decode frame - frame is not complete" << endl; + msg << "(size now: " << frame_size() << ", expected size: " << frame_size_max() << ")" << endl; + msg << "func: " << __PRETTY_FUNCTION__ << endl; + msg << "file: " << __FILE__ << endl; + msg << "line: " << __LINE__ << endl; + throw logic_error(msg.str()); + } + return n; + +} + +void +abstract_data_unit::extend(dibit d) +{ + if(frame_size() < frame_size_max()) { + d_frame_body.push_back(d & 0x2); + d_frame_body.push_back(d & 0x1); + } else { + ostringstream msg; + msg << "cannot extend frame " << endl; + msg << "(size now: " << frame_size() << ", expected size: " << frame_size_max() << ")" << endl; + msg << "func: " << __PRETTY_FUNCTION__ << endl; + msg << "file: " << __FILE__ << endl; + msg << "line: " << __LINE__ << endl; + throw length_error(msg.str()); + } +} + +bool +abstract_data_unit::is_complete() const +{ + return frame_size() >= frame_size_max(); +} + +uint16_t +abstract_data_unit::size() const +{ + return (7 + frame_size_max()) >> 3; +} + +std::string +abstract_data_unit::snapshot() const +{ + string empty; + return empty; +} + +void +abstract_data_unit::dump(ostream& os) const +{ + uint32_t nbits = d_frame_body.size(); + os << setw(4) << nbits << " "; + for(size_t i = 48; i < nbits; ++i) { + os << (d_frame_body[i] ? "#" : "-"); + } + os << endl; +} + +abstract_data_unit::abstract_data_unit(const_bit_queue& frame_body) : + d_frame_body(frame_body.size()) +{ + copy(frame_body.begin(), frame_body.end(), d_frame_body.begin()); +} + +void +abstract_data_unit::do_correct_errors(bit_vector& frame_body) +{ +} + +void +abstract_data_unit::do_decode_audio(const_bit_vector& frame_body, imbe_decoder& imbe) +{ +} + +const_bit_vector& +abstract_data_unit::frame_body() const +{ + return d_frame_body; +} + +uint16_t +abstract_data_unit::frame_size() const +{ + return d_frame_body.size(); +} |