Skip to content

Commit

Permalink
QSO info removed from OLED. QSO info add via CASTInfo.
Browse files Browse the repository at this point in the history
  • Loading branch information
GuusvanDooren committed May 10, 2019
1 parent 5acef27 commit 6d83bfb
Show file tree
Hide file tree
Showing 6 changed files with 223 additions and 25 deletions.
149 changes: 149 additions & 0 deletions CASTInfo.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
/*
* Copyright (C) 2016,2018 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 "CASTInfo.h"

static bool networkInfoInitialized = false;
static unsigned char passCounter = 0;

CCASTInfo::CCASTInfo(CModem* modem) :
CDisplay(),
m_modem(modem),
m_ipaddress()
{
}

CCASTInfo::~CCASTInfo()
{
}

bool CCASTInfo::open()
{
return true;
}

void CCASTInfo::setIdleInt()
{
unsigned char info[100U];
CNetworkInfo* m_network;

passCounter ++;
if (passCounter > 253U)
networkInfoInitialized = false;

if (! networkInfoInitialized) {
//LogMessage("Initialize CNetworkInfo");
info[0]=0;
m_network = new CNetworkInfo;
m_network->getNetworkInterface(info);
m_ipaddress = (char*)info;
delete m_network;

if (m_modem != NULL)
m_modem->writeIPInfo(m_ipaddress);

networkInfoInitialized = true;
passCounter = 0;
}


}

void CCASTInfo::setErrorInt(const char* text)
{
}

void CCASTInfo::setLockoutInt()
{
}

void CCASTInfo::setQuitInt()
{
}

void CCASTInfo::writeDStarInt(const char* my1, const char* my2, const char* your, const char* type, const char* reflector)
{
if (m_modem != NULL)
m_modem->writeDStarInfo(my1, my2, your, type, reflector);
}

void CCASTInfo::clearDStarInt()
{
}

void CCASTInfo::writeDMRInt(unsigned int slotNo, const std::string& src, bool group, const std::string& dst, const char* type)
{
if (m_modem != NULL)
m_modem->writeDMRInfo(slotNo, src, group, dst, type);
}

void CCASTInfo::clearDMRInt(unsigned int slotNo)
{
}

void CCASTInfo::writeFusionInt(const char* source, const char* dest, const char* type, const char* origin)
{
if (m_modem != NULL)
m_modem->writeYSFInfo(source, dest, type, origin);
}

void CCASTInfo::clearFusionInt()
{
}

void CCASTInfo::writeP25Int(const char* source, bool group, unsigned int dest, const char* type)
{
if (m_modem != NULL)
m_modem->writeP25Info(source, group, dest, type);
}

void CCASTInfo::clearP25Int()
{
}

void CCASTInfo::writeNXDNInt(const char* source, bool group, unsigned int dest, const char* type)
{
if (m_modem != NULL)
m_modem->writeNXDNInfo(source, group, dest, type);
}

void CCASTInfo::clearNXDNInt()
{
}

void CCASTInfo::writePOCSAGInt(uint32_t ric, const std::string& message)
{
if (m_modem != NULL)
m_modem->writePOCSAGInfo(ric, message);
}

void CCASTInfo::clearPOCSAGInt()
{
}

void CCASTInfo::writeCWInt()
{
}

void CCASTInfo::clearCWInt()
{
}

void CCASTInfo::close()
{
}
70 changes: 70 additions & 0 deletions CASTInfo.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
/*
* Copyright (C) 2016,2018 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.
*/

#if !defined(CASTINFO_H)
#define CASTINFO_H

#include "Display.h"

#include <string>

#include "NetworkInfo.h"
#include "Modem.h"
class CCASTInfo : public CDisplay
{
public:
CCASTInfo(CModem* modem);
virtual ~CCASTInfo();

virtual bool open();

virtual void close();

protected:
virtual void setIdleInt();
virtual void setErrorInt(const char* text);
virtual void setLockoutInt();
virtual void setQuitInt();

virtual void writeDStarInt(const char* my1, const char* my2, const char* your, const char* type, const char* reflector);
virtual void clearDStarInt();

virtual void writeDMRInt(unsigned int slotNo, const std::string& src, bool group, const std::string& dst, const char* type);
virtual void clearDMRInt(unsigned int slotNo);

virtual void writeFusionInt(const char* source, const char* dest, const char* type, const char* origin);
virtual void clearFusionInt();

virtual void writeP25Int(const char* source, bool group, unsigned int dest, const char* type);
virtual void clearP25Int();

virtual void writeNXDNInt(const char* source, bool group, unsigned int dest, const char* type);
virtual void clearNXDNInt();

virtual void writePOCSAGInt(uint32_t ric, const std::string& message);
virtual void clearPOCSAGInt();

virtual void writeCWInt();
virtual void clearCWInt();

private:
CModem* m_modem;
std::string m_ipaddress;
};

#endif
7 changes: 0 additions & 7 deletions Conf.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,6 @@ m_oledBrightness(0U),
m_oledInvert(false),
m_oledScroll(false),
m_oledRotate(false),
m_oledCast(false),
m_lcdprocAddress(),
m_lcdprocPort(0U),
m_lcdprocLocalPort(0U),
Expand Down Expand Up @@ -791,8 +790,6 @@ bool CConf::read()
m_oledScroll = ::atoi(value) == 1;
else if (::strcmp(key, "Rotate") == 0)
m_oledRotate = ::atoi(value) == 1;
else if (::strcmp(key, "Cast") == 0)
m_oledCast = ::atoi(value) == 1;
} else if (section == SECTION_LCDPROC) {
if (::strcmp(key, "Address") == 0)
m_lcdprocAddress = value;
Expand Down Expand Up @@ -1701,10 +1698,6 @@ bool CConf::getOLEDRotate() const
return m_oledRotate;
}

bool CConf::getOLEDCast() const
{
return m_oledCast;
}

std::string CConf::getLCDprocAddress() const
{
Expand Down
1 change: 0 additions & 1 deletion Conf.h
Original file line number Diff line number Diff line change
Expand Up @@ -254,7 +254,6 @@ class CConf
bool getOLEDInvert() const;
bool getOLEDScroll() const;
bool getOLEDRotate() const;
bool getOLEDCast() const;

// The LCDproc section
std::string getLCDprocAddress() const;
Expand Down
6 changes: 4 additions & 2 deletions Display.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
#include "TFTSerial.h"
#include "LCDproc.h"
#include "Nextion.h"
#include "CASTInfo.h"
#include "Conf.h"
#include "Modem.h"
#include "UMP.h"
Expand Down Expand Up @@ -568,10 +569,11 @@ CDisplay* CDisplay::createDisplay(const CConf& conf, CUMP* ump, CModem* modem)
bool invert = conf.getOLEDInvert();
bool scroll = conf.getOLEDScroll();
bool rotate = conf.getOLEDRotate();
bool cast = conf.getOLEDCast();

display = new COLED(type, brightness, invert, scroll, rotate, conf.getDMRNetworkSlot1(), conf.getDMRNetworkSlot2(), cast ? modem : NULL);
display = new COLED(type, brightness, invert, scroll, rotate, conf.getDMRNetworkSlot1(), conf.getDMRNetworkSlot2(), modem);
#endif
} else if (type == "CAST") {
display = new CCASTInfo(modem);
} else {
LogWarning("No valid display found, disabling");
display = new CNullDisplay;
Expand Down
15 changes: 0 additions & 15 deletions OLED.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -258,9 +258,6 @@ void COLED::setIdleInt()
m_ipaddress = (char*)info;
delete m_network;

if (m_modem != NULL)
m_modem->writeIPInfo(m_ipaddress);

networkInfoInitialized = true;
passCounter = 0;
}
Expand Down Expand Up @@ -331,8 +328,6 @@ void COLED::writeDStarInt(const char* my1, const char* my2, const char* your, co
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writeDStarInfo(my1, my2, your, type, reflector);
}

void COLED::clearDStarInt()
Expand Down Expand Up @@ -393,8 +388,6 @@ void COLED::writeDMRInt(unsigned int slotNo,const std::string& src,bool group,co
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writeDMRInfo(slotNo, src, group, dst, type);
}

void COLED::clearDMRInt(unsigned int slotNo)
Expand Down Expand Up @@ -442,8 +435,6 @@ void COLED::writeFusionInt(const char* source, const char* dest, const char* typ
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writeYSFInfo(source, dest, type, origin);
}

void COLED::clearFusionInt()
Expand Down Expand Up @@ -475,8 +466,6 @@ void COLED::writeP25Int(const char* source, bool group, unsigned int dest, const
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writeP25Info(source, group, dest, type);
}

void COLED::clearP25Int()
Expand Down Expand Up @@ -508,8 +497,6 @@ void COLED::writeNXDNInt(const char* source, bool group, unsigned int dest, cons
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writeNXDNInfo(source, group, dest, type);
}

void COLED::clearNXDNInt()
Expand Down Expand Up @@ -541,8 +528,6 @@ void COLED::writePOCSAGInt(uint32_t ric, const std::string& message)
OLED_statusbar();
m_display.display();

if (m_modem != NULL)
m_modem->writePOCSAGInfo(ric, message);
}

void COLED::clearPOCSAGInt()
Expand Down

0 comments on commit 6d83bfb

Please sign in to comment.