// // StaticAnalyser.hpp // Clock Signal // // Created by Thomas Harte on 23/08/2016. // Copyright 2016 Thomas Harte. All rights reserved. // #pragma once #include "../Machines.hpp" #include "../../Storage/Cartridge/Cartridge.hpp" #include "../../Storage/Disk/Disk.hpp" #include "../../Storage/MassStorage/MassStorageDevice.hpp" #include "../../Storage/Tape/Tape.hpp" #include "../../Reflection/Struct.hpp" #include #include #include namespace Analyser::Static { struct State; /*! A list of disks, tapes and cartridges, and possibly a state snapshot. */ struct Media { std::vector> disks; std::vector> tapes; std::vector> cartridges; std::vector> mass_storage_devices; bool empty() const { return disks.empty() && tapes.empty() && cartridges.empty() && mass_storage_devices.empty(); } Media &operator +=(const Media &rhs) { #define append(name) name.insert(name.end(), rhs.name.begin(), rhs.name.end()); append(disks); append(tapes); append(cartridges); append(mass_storage_devices); #undef append return *this; } }; /*! Describes a machine and possibly its state; conventionally subclassed to add other machine-specific configuration fields and any necessary instructions on how to launch any software provided, plus a measure of confidence in this target's correctness. */ struct Target { Target(Machine machine) : machine(machine) {} virtual ~Target() {} // This field is entirely optional. std::unique_ptr state; Machine machine; Media media; float confidence = 0.0f; }; typedef std::vector> TargetList; /*! Attempts, through any available means, to return a list of potential targets for the file with the given name. @returns The list of potential targets, sorted from most to least probable. */ TargetList GetTargets(const std::string &file_name); /*! Inspects the supplied file and determines the media included. */ Media GetMedia(const std::string &file_name); }