2018-08-31 11:48:35 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
2019-12-31 17:18:56 +00:00
|
|
|
// Copyright (c) 1995-2020 by Bradford W. Mott, Stephen Anthony
|
2018-08-31 11:48:35 +00:00
|
|
|
// and the Stella Team
|
|
|
|
//
|
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef BANKSWITCH_HXX
|
|
|
|
#define BANKSWITCH_HXX
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
#include "FSNode.hxx"
|
|
|
|
#include "bspf.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
This class contains all information about the bankswitch schemes supported
|
|
|
|
by Stella, as well as convenience functions to map from scheme type to
|
|
|
|
readable string, and vice-versa.
|
|
|
|
|
|
|
|
It also includes all logic that determines what a 'valid' rom filename is.
|
|
|
|
That is, all extensions that represent valid schemes.
|
|
|
|
|
|
|
|
@author Stephen Anthony
|
|
|
|
*/
|
|
|
|
class Bankswitch
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// Currently supported bankswitch schemes
|
|
|
|
enum class Type {
|
|
|
|
_AUTO, _0840, _2IN1, _4IN1, _8IN1, _16IN1, _32IN1,
|
|
|
|
_64IN1, _128IN1, _2K, _3E, _3EP, _3F, _4A50,
|
|
|
|
_4K, _4KSC, _AR, _BF, _BFSC, _BUS, _CDF,
|
|
|
|
_CM, _CTY, _CV, _CVP, _DASH, _DF, _DFSC,
|
|
|
|
_DPC, _DPCP, _E0, _E7, _E78K, _EF, _EFSC,
|
|
|
|
_F0, _F4, _F4SC, _F6, _F6SC, _F8, _F8SC,
|
2019-11-02 11:23:03 +00:00
|
|
|
_FA, _FA2, _FC, _FE, _MDM, _SB, _UA,
|
|
|
|
_UASW, _WD, _WDSW, _X07,
|
2018-08-31 11:48:35 +00:00
|
|
|
#ifdef CUSTOM_ARM
|
|
|
|
_CUSTOM,
|
|
|
|
#endif
|
|
|
|
NumSchemes
|
|
|
|
};
|
|
|
|
|
|
|
|
// Info about the various bankswitch schemes, useful for displaying
|
|
|
|
// in GUI dropdown boxes, etc
|
|
|
|
struct Description {
|
|
|
|
const char* const name;
|
|
|
|
const char* const desc;
|
|
|
|
};
|
2019-12-27 22:52:09 +00:00
|
|
|
static const std::array<Description, static_cast<int>(Type::NumSchemes)> BSList;
|
2018-08-31 11:48:35 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
// Convert BSType enum to string
|
|
|
|
static string typeToName(Bankswitch::Type type);
|
|
|
|
|
|
|
|
// Convert string to BSType enum
|
|
|
|
static Bankswitch::Type nameToType(const string& name);
|
|
|
|
|
2019-12-15 16:19:08 +00:00
|
|
|
// Convert BSType enum to description string
|
|
|
|
static string typeToDesc(Bankswitch::Type type);
|
|
|
|
|
2018-08-31 11:48:35 +00:00
|
|
|
// Determine bankswitch type by filename extension
|
|
|
|
// Use '_AUTO' if unknown
|
|
|
|
static Bankswitch::Type typeFromExtension(const FilesystemNode& file);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Is this a valid ROM filename (does it have a valid extension?).
|
|
|
|
|
2018-09-01 01:59:19 +00:00
|
|
|
@param name Filename of potential ROM file
|
2018-08-31 11:48:35 +00:00
|
|
|
@param ext The extension extracted from the given file
|
|
|
|
*/
|
2018-09-01 01:59:19 +00:00
|
|
|
static bool isValidRomName(const string& name, string& ext);
|
2018-08-31 11:48:35 +00:00
|
|
|
|
|
|
|
/**
|
2018-09-01 01:59:19 +00:00
|
|
|
Convenience functions for different parameter types.
|
2018-08-31 11:48:35 +00:00
|
|
|
*/
|
2018-09-01 01:59:19 +00:00
|
|
|
static bool isValidRomName(const FilesystemNode& name, string& ext);
|
2018-08-31 11:48:35 +00:00
|
|
|
static bool isValidRomName(const FilesystemNode& name);
|
2018-09-01 01:59:19 +00:00
|
|
|
static bool isValidRomName(const string& name);
|
2018-08-31 11:48:35 +00:00
|
|
|
|
2020-01-21 15:50:48 +00:00
|
|
|
// Output operator
|
|
|
|
friend ostream& operator<<(ostream& os, const Bankswitch::Type& t) {
|
|
|
|
return os << typeToName(t);
|
|
|
|
}
|
|
|
|
|
2018-08-31 11:48:35 +00:00
|
|
|
private:
|
|
|
|
struct TypeComparator {
|
|
|
|
bool operator() (const string& a, const string& b) const {
|
|
|
|
return BSPF::compareIgnoreCase(a, b) < 0;
|
|
|
|
}
|
|
|
|
};
|
2019-12-27 22:52:09 +00:00
|
|
|
using ExtensionMap = const std::map<string, Bankswitch::Type, TypeComparator>;
|
2018-08-31 11:48:35 +00:00
|
|
|
static ExtensionMap ourExtensions;
|
|
|
|
|
2019-12-27 22:52:09 +00:00
|
|
|
using NameToTypeMap = const std::map<string, Bankswitch::Type, TypeComparator>;
|
2018-09-01 00:34:31 +00:00
|
|
|
static NameToTypeMap ourNameToTypes;
|
|
|
|
|
2018-08-31 11:48:35 +00:00
|
|
|
private:
|
|
|
|
// Following constructors and assignment operators not supported
|
|
|
|
Bankswitch() = delete;
|
|
|
|
Bankswitch(const Bankswitch&) = delete;
|
|
|
|
Bankswitch(Bankswitch&&) = delete;
|
|
|
|
Bankswitch& operator=(const Bankswitch&) = delete;
|
|
|
|
Bankswitch& operator=(Bankswitch&&) = delete;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|