Files
QTeletextMaker/pagebase.cpp
G.K.MacGregor a1e0986e5c Port saving pages to packet handling framework
Any unhandled packets within pages are now loaded and saved intact
albeit with no way to edit them.

File handling is now two separate processes: parsing TTI files into
packets, and then interpreting the packets into how pages are
displayed. This will allow us to import other file formats, and to deal
with page functions other than Level 1 Teletext pages.
2020-09-15 22:37:50 +01:00

116 lines
3.0 KiB
C++

/*
* Copyright (C) 2020 Gavin MacGregor
*
* This file is part of QTeletextMaker.
*
* QTeletextMaker 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 of the License, or
* (at your option) any later version.
*
* QTeletextMaker 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 QTeletextMaker. If not, see <https://www.gnu.org/licenses/>.
*/
#include <QByteArray>
#include "pagebase.h"
PageBase::PageBase()
{
m_pageFunction = PFLOP;
m_packetCoding = PC7bit;
// We use nullptrs to keep track of allocated packets, so initialise them this way
for (int i=0; i<90; i++)
m_packets[i] = nullptr;
}
PageBase::~PageBase()
{
for (int i=0; i<90; i++)
if (m_packets[i] != nullptr)
delete m_packets[i];
}
QByteArray PageBase::packet(int packetNumber, int designationCode) const
{
int packetArrayIndex = packetNumber;
if (packetNumber >= 26)
packetArrayIndex += (packetNumber - 26) * 16 + designationCode;
if (m_packets[packetArrayIndex] == nullptr)
return QByteArray(); // Blank result
return *m_packets[packetArrayIndex];
}
bool PageBase::packetNeeded(int packetNumber, int designationCode) const
{
int packetArrayIndex = packetNumber;
if (packetNumber >= 26)
packetArrayIndex += (packetNumber - 26) * 16 + designationCode;
return m_packets[packetArrayIndex] != nullptr;
}
bool PageBase::setPacket(int packetNumber, QByteArray packetContents)
{
return setPacket(packetNumber, 0, packetContents);
}
bool PageBase::setPacket(int packetNumber, int designationCode, QByteArray packetContents)
{
int packetArrayIndex = packetNumber;
if (packetNumber >= 26)
packetArrayIndex += (packetNumber - 26) * 16 + designationCode;
if (m_packets[packetArrayIndex] == nullptr)
m_packets[packetArrayIndex] = new QByteArray(40, 0x00);
*m_packets[packetArrayIndex] = packetContents;
return true;
}
bool PageBase::deletePacket(int packetNumber, int designationCode)
{
int packetArrayIndex = packetNumber;
if (packetNumber >= 26)
packetArrayIndex += (packetNumber - 26) * 16 + designationCode;
if (m_packets[packetArrayIndex] != nullptr) {
delete m_packets[packetArrayIndex];
m_packets[packetArrayIndex] = nullptr;
}
return true;
}
PageBase::PacketCodingEnum PageBase::packetCoding(int packetNumber, int designationCode) const
{
switch (packetNumber) {
case 26:
case 28:
return PC18bit;
case 27:
return PC4bit;
default:
return m_packetCoding;
}
}
bool PageBase::setPageFunction(PageBase::PageFunctionEnum newPageFunction)
{
m_pageFunction = newPageFunction;
return true;
}
bool PageBase::setPacketCoding(PageBase::PacketCodingEnum newPacketEncoding)
{
m_packetCoding = newPacketEncoding;
return true;
}