You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

271 lines
5.9 KiB

/*
* Copyright (C) 2009,2012 by Jonathan Naylor G4KLX
*
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "CCITTChecksumReverse.h"
#include "HeaderData.h"
#include "DStarDefines.h"
CHeaderData::CHeaderData() :
m_time(),
m_myCall1(),
m_myCall2(),
m_yourCall(),
m_rptCall1(),
m_rptCall2(),
m_flag1(0x00),
m_flag2(0x00),
m_flag3(0x00),
m_valid(false)
{
}
CHeaderData::CHeaderData(const CHeaderData& header) :
m_time(header.m_time),
m_myCall1(header.m_myCall1),
m_myCall2(header.m_myCall2),
m_yourCall(header.m_yourCall),
m_rptCall1(header.m_rptCall1),
m_rptCall2(header.m_rptCall2),
m_flag1(header.m_flag1),
m_flag2(header.m_flag2),
m_flag3(header.m_flag3),
m_valid(header.m_valid)
{
}
CHeaderData::CHeaderData(const unsigned char* data, unsigned int length, bool check) :
m_time(),
m_myCall1(),
m_myCall2(),
m_yourCall(),
m_rptCall1(),
m_rptCall2(),
m_flag1(0x00),
m_flag2(0x00),
m_flag3(0x00),
m_valid(true)
{
wxASSERT(data != NULL);
wxASSERT(length >= (RADIO_HEADER_LENGTH_BYTES - 2U));
const unsigned char* p = data;
m_flag1 = *p++;
m_flag2 = *p++;
m_flag3 = *p++;
m_rptCall2 = wxString((const char*)p, wxConvLocal, LONG_CALLSIGN_LENGTH);
p += LONG_CALLSIGN_LENGTH;
m_rptCall1 = wxString((const char*)p, wxConvLocal, LONG_CALLSIGN_LENGTH);
p += LONG_CALLSIGN_LENGTH;
m_yourCall = wxString((const char*)p, wxConvLocal, LONG_CALLSIGN_LENGTH);
p += LONG_CALLSIGN_LENGTH;
m_myCall1 = wxString((const char*)p, wxConvLocal, LONG_CALLSIGN_LENGTH);
p += LONG_CALLSIGN_LENGTH;
m_myCall2 = wxString((const char*)p, wxConvLocal, SHORT_CALLSIGN_LENGTH);
m_time.SetToCurrent();
// We have a checksum, check it if asked
if (length >= RADIO_HEADER_LENGTH_BYTES && check) {
CCCITTChecksumReverse cksum;
cksum.update(data, RADIO_HEADER_LENGTH_BYTES - 2U);
m_valid = cksum.check(data + RADIO_HEADER_LENGTH_BYTES - 2U);
}
}
CHeaderData::CHeaderData(const wxString& myCall1, const wxString& myCall2, const wxString& yourCall,
const wxString& rptCall1, const wxString& rptCall2, unsigned char flag1,
unsigned char flag2, unsigned char flag3) :
m_time(),
m_myCall1(myCall1),
m_myCall2(myCall2),
m_yourCall(yourCall),
m_rptCall1(rptCall1),
m_rptCall2(rptCall2),
m_flag1(flag1),
m_flag2(flag2),
m_flag3(flag3),
m_valid(true)
{
m_time.SetToCurrent();
m_myCall1.Append(wxT(' '), LONG_CALLSIGN_LENGTH);
m_myCall2.Append(wxT(' '), SHORT_CALLSIGN_LENGTH);
m_yourCall.Append(wxT(' '), LONG_CALLSIGN_LENGTH);
m_rptCall1.Append(wxT(' '), LONG_CALLSIGN_LENGTH);
m_rptCall2.Append(wxT(' '), LONG_CALLSIGN_LENGTH);
m_myCall1.Truncate(LONG_CALLSIGN_LENGTH);
m_myCall2.Truncate(SHORT_CALLSIGN_LENGTH);
m_yourCall.Truncate(LONG_CALLSIGN_LENGTH);
m_rptCall1.Truncate(LONG_CALLSIGN_LENGTH);
m_rptCall2.Truncate(LONG_CALLSIGN_LENGTH);
}
CHeaderData::~CHeaderData()
{
}
wxDateTime CHeaderData::getTime() const
{
return m_time;
}
wxString CHeaderData::getMyCall1() const
{
return m_myCall1;
}
wxString CHeaderData::getMyCall2() const
{
return m_myCall2;
}
wxString CHeaderData::getYourCall() const
{
return m_yourCall;
}
wxString CHeaderData::getRptCall1() const
{
return m_rptCall1;
}
wxString CHeaderData::getRptCall2() const
{
return m_rptCall2;
}
unsigned char CHeaderData::getFlag1() const
{
return m_flag1;
}
unsigned char CHeaderData::getFlag2() const
{
return m_flag2;
}
unsigned char CHeaderData::getFlag3() const
{
return m_flag3;
}
void CHeaderData::setRepeaterMode(bool set)
{
if (set) {
m_flag1 |= REPEATER_MASK;
} else {
m_flag1 &= ~REPEATER_MASK;
m_rptCall1 = wxT("DIRECT ");
m_rptCall2 = wxT("DIRECT ");
}
}
bool CHeaderData::isRepeaterMode() const
{
return (m_flag1 & REPEATER_MASK) == REPEATER_MASK;
}
void CHeaderData::setDataPacket(bool set)
{
if (set)
m_flag1 |= DATA_MASK;
else
m_flag1 &= ~DATA_MASK;
}
bool CHeaderData::isDataPacket() const
{
return (m_flag1 & DATA_MASK) == DATA_MASK;
}
void CHeaderData::setInterrupted(bool set)
{
if (set)
m_flag1 |= INTERRUPTED_MASK;
else
m_flag1 &= ~INTERRUPTED_MASK;
}
bool CHeaderData::isInterrupted() const
{
return (m_flag1 & INTERRUPTED_MASK) == INTERRUPTED_MASK;
}
void CHeaderData::setControlSignal(bool set)
{
if (set)
m_flag1 |= CONTROL_SIGNAL_MASK;
else
m_flag1 &= ~CONTROL_SIGNAL_MASK;
}
bool CHeaderData::isControlSignal() const
{
return (m_flag1 & CONTROL_SIGNAL_MASK) == CONTROL_SIGNAL_MASK;
}
void CHeaderData::setUrgent(bool set)
{
if (set)
m_flag1 |= URGENT_MASK;
else
m_flag1 &= ~URGENT_MASK;
}
bool CHeaderData::isUrgent() const
{
return (m_flag1 & URGENT_MASK) == URGENT_MASK;
}
void CHeaderData::setRepeaterFlags(unsigned char set)
{
m_flag1 &= ~REPEATER_CONTROL_MASK;
m_flag1 |= set & REPEATER_CONTROL_MASK;
}
unsigned char CHeaderData::getRepeaterFlags() const
{
return m_flag1 & REPEATER_CONTROL_MASK;
}
bool CHeaderData::isValid() const
{
return m_valid;
}
void CHeaderData::reset()
{
m_myCall1 = wxT(" ");
m_myCall2 = wxT(" ");
m_yourCall = wxT("CQCQCQ ");
m_rptCall1 = wxT("DIRECT ");
m_rptCall2 = wxT("DIRECT ");
m_flag1 = 0x00;
m_flag2 = 0x00;
m_flag3 = 0x00;
}

Powered by TurnKey Linux.