mirror of
https://github.com/TomHarte/CLK.git
synced 2024-12-12 08:30:05 +00:00
Route +4 software into a non-functional +4.
This commit is contained in:
parent
c14a4515ce
commit
9fcb634510
@ -8,13 +8,42 @@
|
|||||||
|
|
||||||
#include "Plus4.hpp"
|
#include "Plus4.hpp"
|
||||||
|
|
||||||
|
#include "../../MachineTypes.hpp"
|
||||||
|
|
||||||
|
#include "../../../Analyser/Static/Commodore/Target.hpp"
|
||||||
|
|
||||||
using namespace Commodore::Plus4;
|
using namespace Commodore::Plus4;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
class ConcreteMachine:
|
||||||
|
public MachineTypes::TimedMachine,
|
||||||
|
public MachineTypes::ScanProducer,
|
||||||
|
public Machine {
|
||||||
|
public:
|
||||||
|
ConcreteMachine(const Analyser::Static::Commodore::Target &target, const ROMMachine::ROMFetcher &rom_fetcher) {
|
||||||
|
(void)target;
|
||||||
|
(void)rom_fetcher;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
void set_scan_target(Outputs::Display::ScanTarget *const) final {
|
||||||
|
}
|
||||||
|
|
||||||
|
Outputs::Display::ScanStatus get_scaled_scan_status() const final {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
void run_for(const Cycles) final {
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
std::unique_ptr<Machine> Machine::Plus4(
|
std::unique_ptr<Machine> Machine::Plus4(
|
||||||
const Analyser::Static::Target *target,
|
const Analyser::Static::Target *target,
|
||||||
const ROMMachine::ROMFetcher &rom_fetcher
|
const ROMMachine::ROMFetcher &rom_fetcher
|
||||||
) {
|
) {
|
||||||
(void)target;
|
using Target = Analyser::Static::Commodore::Target;
|
||||||
(void)rom_fetcher;
|
const Target *const commodore_target = dynamic_cast<const Target *>(target);
|
||||||
return nullptr;
|
return std::make_unique<ConcreteMachine>(*commodore_target, rom_fetcher);
|
||||||
}
|
}
|
||||||
|
@ -20,14 +20,14 @@ namespace MachineTypes {
|
|||||||
by a ScanTarget.
|
by a ScanTarget.
|
||||||
*/
|
*/
|
||||||
class ScanProducer {
|
class ScanProducer {
|
||||||
public:
|
public:
|
||||||
/*!
|
/*!
|
||||||
Causes the machine to set up its display and, if it has one, speaker.
|
Causes the machine to set up its display and, if it has one, speaker.
|
||||||
|
|
||||||
The @c scan_target will receive all video output; the caller guarantees
|
The @c scan_target will receive all video output; the caller guarantees
|
||||||
that it is non-null.
|
that it is non-null.
|
||||||
*/
|
*/
|
||||||
virtual void set_scan_target(Outputs::Display::ScanTarget *scan_target) = 0;
|
virtual void set_scan_target(Outputs::Display::ScanTarget *) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@returns The current scan status.
|
@returns The current scan status.
|
||||||
@ -39,7 +39,7 @@ class ScanProducer {
|
|||||||
return get_scaled_scan_status() / float(timed_machine->get_clock_rate());
|
return get_scaled_scan_status() / float(timed_machine->get_clock_rate());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual Outputs::Display::ScanStatus get_scaled_scan_status() const {
|
virtual Outputs::Display::ScanStatus get_scaled_scan_status() const {
|
||||||
// This deliberately sets up an infinite loop if the user hasn't
|
// This deliberately sets up an infinite loop if the user hasn't
|
||||||
// overridden at least one of this or get_scan_status.
|
// overridden at least one of this or get_scan_status.
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#include "../Atari/2600/Atari2600.hpp"
|
#include "../Atari/2600/Atari2600.hpp"
|
||||||
#include "../Atari/ST/AtariST.hpp"
|
#include "../Atari/ST/AtariST.hpp"
|
||||||
#include "../ColecoVision/ColecoVision.hpp"
|
#include "../ColecoVision/ColecoVision.hpp"
|
||||||
|
#include "../Commodore/Plus4/Plus4.hpp"
|
||||||
#include "../Commodore/Vic-20/Vic20.hpp"
|
#include "../Commodore/Vic-20/Vic20.hpp"
|
||||||
#include "../Enterprise/Enterprise.hpp"
|
#include "../Enterprise/Enterprise.hpp"
|
||||||
#include "../MasterSystem/MasterSystem.hpp"
|
#include "../MasterSystem/MasterSystem.hpp"
|
||||||
@ -68,6 +69,7 @@ std::unique_ptr<Machine::DynamicMachine> Machine::MachineForTarget(const Analyse
|
|||||||
Bind(Atari2600)
|
Bind(Atari2600)
|
||||||
BindD(Atari::ST, AtariST)
|
BindD(Atari::ST, AtariST)
|
||||||
BindD(Coleco::Vision, ColecoVision)
|
BindD(Coleco::Vision, ColecoVision)
|
||||||
|
BindD(Commodore::Plus4, Plus4)
|
||||||
BindD(Commodore::Vic20, Vic20)
|
BindD(Commodore::Vic20, Vic20)
|
||||||
Bind(Electron)
|
Bind(Electron)
|
||||||
Bind(Enterprise)
|
Bind(Enterprise)
|
||||||
@ -145,6 +147,7 @@ std::string Machine::ShortNameForTargetMachine(const Analyser::Machine machine)
|
|||||||
case Analyser::Machine::MasterSystem: return "MasterSystem";
|
case Analyser::Machine::MasterSystem: return "MasterSystem";
|
||||||
case Analyser::Machine::MSX: return "MSX";
|
case Analyser::Machine::MSX: return "MSX";
|
||||||
case Analyser::Machine::Oric: return "Oric";
|
case Analyser::Machine::Oric: return "Oric";
|
||||||
|
case Analyser::Machine::Plus4: return "Plus4";
|
||||||
case Analyser::Machine::PCCompatible: return "PCCompatible";
|
case Analyser::Machine::PCCompatible: return "PCCompatible";
|
||||||
case Analyser::Machine::Vic20: return "Vic20";
|
case Analyser::Machine::Vic20: return "Vic20";
|
||||||
case Analyser::Machine::ZX8081: return "ZX8081";
|
case Analyser::Machine::ZX8081: return "ZX8081";
|
||||||
@ -170,6 +173,7 @@ std::string Machine::LongNameForTargetMachine(Analyser::Machine machine) {
|
|||||||
case Analyser::Machine::MasterSystem: return "Sega Master System";
|
case Analyser::Machine::MasterSystem: return "Sega Master System";
|
||||||
case Analyser::Machine::MSX: return "MSX";
|
case Analyser::Machine::MSX: return "MSX";
|
||||||
case Analyser::Machine::Oric: return "Oric";
|
case Analyser::Machine::Oric: return "Oric";
|
||||||
|
case Analyser::Machine::Plus4: return "Commodore C16+4";
|
||||||
case Analyser::Machine::PCCompatible: return "PC Compatible";
|
case Analyser::Machine::PCCompatible: return "PC Compatible";
|
||||||
case Analyser::Machine::Vic20: return "Vic 20";
|
case Analyser::Machine::Vic20: return "Vic 20";
|
||||||
case Analyser::Machine::ZX8081: return "ZX80/81";
|
case Analyser::Machine::ZX8081: return "ZX80/81";
|
||||||
@ -202,6 +206,7 @@ std::vector<std::string> Machine::AllMachines(Type type, bool long_names) {
|
|||||||
AddName(Macintosh);
|
AddName(Macintosh);
|
||||||
AddName(MSX);
|
AddName(MSX);
|
||||||
AddName(Oric);
|
AddName(Oric);
|
||||||
|
AddName(Plus4);
|
||||||
AddName(PCCompatible);
|
AddName(PCCompatible);
|
||||||
AddName(Vic20);
|
AddName(Vic20);
|
||||||
AddName(ZX8081);
|
AddName(ZX8081);
|
||||||
@ -230,6 +235,7 @@ std::map<std::string, std::unique_ptr<Reflection::Struct>> Machine::AllOptionsBy
|
|||||||
Emplace(MasterSystem, Sega::MasterSystem::Machine);
|
Emplace(MasterSystem, Sega::MasterSystem::Machine);
|
||||||
Emplace(MSX, MSX::Machine);
|
Emplace(MSX, MSX::Machine);
|
||||||
Emplace(Oric, Oric::Machine);
|
Emplace(Oric, Oric::Machine);
|
||||||
|
// Emplace(Plus4, Commodore::Plus4::Machine); // There are no options yet.
|
||||||
Emplace(PCCompatible, PCCompatible::Machine);
|
Emplace(PCCompatible, PCCompatible::Machine);
|
||||||
Emplace(Vic20, Commodore::Vic20::Machine);
|
Emplace(Vic20, Commodore::Vic20::Machine);
|
||||||
Emplace(ZX8081, Sinclair::ZX8081::Machine);
|
Emplace(ZX8081, Sinclair::ZX8081::Machine);
|
||||||
@ -258,6 +264,7 @@ std::map<std::string, std::unique_ptr<Analyser::Static::Target>> Machine::Target
|
|||||||
Add(Macintosh);
|
Add(Macintosh);
|
||||||
Add(MSX);
|
Add(MSX);
|
||||||
Add(Oric);
|
Add(Oric);
|
||||||
|
AddMapped(Plus4, Commodore);
|
||||||
Add(PCCompatible);
|
Add(PCCompatible);
|
||||||
AddMapped(Vic20, Commodore);
|
AddMapped(Vic20, Commodore);
|
||||||
Add(ZX8081);
|
Add(ZX8081);
|
||||||
|
Loading…
Reference in New Issue
Block a user