2017-11-05 12:49:28 -05:00
|
|
|
//
|
|
|
|
// MachineForTarget.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 04/11/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-11-05 12:49:28 -05:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef MachineForTarget_hpp
|
|
|
|
#define MachineForTarget_hpp
|
|
|
|
|
2018-01-24 21:48:44 -05:00
|
|
|
#include "../../Analyser/Static/StaticAnalyser.hpp"
|
2020-03-19 23:24:06 -04:00
|
|
|
#include "../../Reflection/Struct.hpp"
|
2017-11-05 12:49:28 -05:00
|
|
|
|
2018-01-29 21:49:49 -05:00
|
|
|
#include "../DynamicMachine.hpp"
|
2020-04-01 23:19:34 -04:00
|
|
|
#include "../ROMMachine.hpp"
|
2017-11-05 12:49:28 -05:00
|
|
|
|
2017-11-20 21:55:32 -05:00
|
|
|
#include <map>
|
2020-03-12 20:56:02 -04:00
|
|
|
#include <memory>
|
2017-11-05 20:12:01 -05:00
|
|
|
#include <string>
|
2018-01-23 22:18:16 -05:00
|
|
|
#include <vector>
|
2017-11-05 20:12:01 -05:00
|
|
|
|
2020-03-15 12:54:55 -04:00
|
|
|
/*!
|
2020-03-15 21:50:43 -04:00
|
|
|
This namespace acts as a grab-bag of functions that allow a client to:
|
|
|
|
|
|
|
|
(i) discover the total list of implemented machines;
|
|
|
|
(ii) discover the construction and runtime options available for controlling them; and
|
|
|
|
(iii) create any implemented machine via its construction options.
|
|
|
|
|
|
|
|
See Reflection::Struct and Reflection::Enum for getting dynamic information from the
|
|
|
|
Targets that this namespace deals in.
|
2020-03-15 12:54:55 -04:00
|
|
|
*/
|
2017-11-05 12:49:28 -05:00
|
|
|
namespace Machine {
|
|
|
|
|
2018-01-25 18:28:19 -05:00
|
|
|
enum class Error {
|
|
|
|
None,
|
2018-07-10 20:00:46 -04:00
|
|
|
UnknownError,
|
2018-01-25 18:28:19 -05:00
|
|
|
UnknownMachine,
|
2018-01-28 22:22:21 -05:00
|
|
|
MissingROM,
|
|
|
|
NoTargets
|
2018-01-25 18:28:19 -05:00
|
|
|
};
|
|
|
|
|
2017-11-05 12:49:28 -05:00
|
|
|
/*!
|
|
|
|
Allocates an instance of DynamicMachine holding a machine that can
|
2018-01-23 22:18:16 -05:00
|
|
|
receive the supplied static analyser result. The machine has been allocated
|
|
|
|
on the heap. It is the caller's responsibility to delete the class when finished.
|
2017-11-05 12:49:28 -05:00
|
|
|
*/
|
2018-04-14 19:46:38 -04:00
|
|
|
DynamicMachine *MachineForTargets(const Analyser::Static::TargetList &targets, const ::ROMMachine::ROMFetcher &rom_fetcher, Error &error);
|
2017-11-05 12:49:28 -05:00
|
|
|
|
2020-03-15 12:54:55 -04:00
|
|
|
/*!
|
|
|
|
Allocates an instance of DynamicMaachine holding the machine described
|
|
|
|
by @c target. It is the caller's responsibility to delete the class when finished.
|
|
|
|
*/
|
|
|
|
DynamicMachine *MachineForTarget(const Analyser::Static::Target *target, const ROMMachine::ROMFetcher &rom_fetcher, Machine::Error &error);
|
|
|
|
|
2017-11-05 20:12:01 -05:00
|
|
|
/*!
|
|
|
|
Returns a short string name for the machine identified by the target,
|
|
|
|
which is guaranteed not to have any spaces or other potentially
|
|
|
|
filesystem-bothering contents.
|
|
|
|
*/
|
2018-01-24 21:48:44 -05:00
|
|
|
std::string ShortNameForTargetMachine(const Analyser::Machine target);
|
2017-11-20 21:55:32 -05:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Returns a long string name for the machine identified by the target,
|
|
|
|
usable for presentation to a human.
|
|
|
|
*/
|
2018-01-24 21:48:44 -05:00
|
|
|
std::string LongNameForTargetMachine(const Analyser::Machine target);
|
2017-11-20 21:55:32 -05:00
|
|
|
|
2020-03-18 23:11:25 -04:00
|
|
|
enum class Type {
|
|
|
|
RequiresMedia,
|
|
|
|
DoesntRequireMedia,
|
|
|
|
Any
|
|
|
|
};
|
|
|
|
|
2020-03-15 00:15:19 -04:00
|
|
|
/*!
|
2020-03-18 23:11:25 -04:00
|
|
|
@param type the type of machines to include.
|
2020-03-15 21:50:43 -04:00
|
|
|
@param long_names If this is @c true then long names will be returned; otherwise short names will be returned.
|
|
|
|
|
|
|
|
@returns A list of all available machines. Names are always guaranteed to be in the same order.
|
2020-03-15 00:15:19 -04:00
|
|
|
*/
|
2020-03-18 23:11:25 -04:00
|
|
|
std::vector<std::string> AllMachines(Type type, bool long_names);
|
2020-03-15 00:15:19 -04:00
|
|
|
|
2017-11-20 21:55:32 -05:00
|
|
|
/*!
|
2020-03-15 21:50:43 -04:00
|
|
|
Returns a map from long machine name to the list of options that machine exposes, for all machines.
|
2020-06-23 23:27:56 -04:00
|
|
|
In all cases, user-friendly selections will have been filled in by default.
|
2017-11-20 21:55:32 -05:00
|
|
|
*/
|
2020-03-15 23:48:53 -04:00
|
|
|
std::map<std::string, std::unique_ptr<Reflection::Struct>> AllOptionsByMachineName();
|
2017-11-05 20:12:01 -05:00
|
|
|
|
2020-03-15 12:54:55 -04:00
|
|
|
/*!
|
|
|
|
Returns a map from long machine name to appropriate instances of Target for the machine.
|
|
|
|
|
|
|
|
NB: Usually the instances of Target can be dynamic_casted to Reflection::Struct in order to determine available properties.
|
|
|
|
*/
|
|
|
|
std::map<std::string, std::unique_ptr<Analyser::Static::Target>> TargetsByMachineName(bool meaningful_without_media_only);
|
2020-03-12 20:56:02 -04:00
|
|
|
|
2017-11-05 12:49:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* MachineForTarget_hpp */
|