mirror of
				https://github.com/TomHarte/CLK.git
				synced 2025-10-25 09:27:01 +00:00 
			
		
		
		
	Advanced this just enough to suggest a loading command for most things.
This commit is contained in:
		| @@ -9,6 +9,35 @@ | ||||
| #include "StaticAnalyser.hpp" | ||||
| #include "../../Storage/Disk/Parsers/CPM.hpp" | ||||
|  | ||||
| static void InspectDataCatalogue( | ||||
| 	const std::unique_ptr<Storage::Disk::CPM::Catalogue> &data_catalogue, | ||||
| 	StaticAnalyser::Target &target) { | ||||
| 	// If there's just one file, run that. | ||||
| 	if(data_catalogue->files.size() == 1) { | ||||
| 		target.loadingCommand = "run\"" + data_catalogue->files[0].name + "\n"; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	// If only one file is [potentially] BASIC, run that one. | ||||
| 	int basic_files = 0; | ||||
| 	size_t last_basic_file = 0; | ||||
| 	for(size_t c = 0; c < data_catalogue->files.size(); c++) { | ||||
| 		if(!((data_catalogue->files[c].data[18] >> 1) & 7)) { | ||||
| 			basic_files++; | ||||
| 			last_basic_file = c; | ||||
| 		} | ||||
| 	} | ||||
| 	if(basic_files == 1) { | ||||
| 		target.loadingCommand = "run\"" + data_catalogue->files[last_basic_file].name + "\n"; | ||||
| 		return; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| static void InspectSystemCatalogue( | ||||
| 	const std::unique_ptr<Storage::Disk::CPM::Catalogue> &data_catalogue, | ||||
| 	StaticAnalyser::Target &target) { | ||||
| } | ||||
|  | ||||
| void StaticAnalyser::AmstradCPC::AddTargets( | ||||
| 	const std::list<std::shared_ptr<Storage::Disk::Disk>> &disks, | ||||
| 	const std::list<std::shared_ptr<Storage::Tape::Tape>> &tapes, | ||||
| @@ -21,19 +50,38 @@ void StaticAnalyser::AmstradCPC::AddTargets( | ||||
| 	target.tapes = tapes; | ||||
| 	target.cartridges = cartridges; | ||||
|  | ||||
| 	target.amstradcpc.model = target.disks.empty() ? AmstradCPCModel::CPC464 : AmstradCPCModel::CPC6128; | ||||
| 	target.amstradcpc.model = AmstradCPCModel::CPC6128; | ||||
|  | ||||
| 	if(!target.tapes.empty()) { | ||||
| 		target.loadingCommand = "|tape\nrun\"\n"; | ||||
| 	} | ||||
|  | ||||
| 	if(!target.disks.empty()) { | ||||
| 		// This is CPC data format. | ||||
| 		Storage::Disk::CPM::ParameterBlock parameters; | ||||
| 		parameters.sectors_per_track = 9; | ||||
| 		parameters.block_size = 1024; | ||||
| 		parameters.first_sector = 0xc1; | ||||
| 		parameters.catalogue_allocation_bitmap = 0xc000; | ||||
| 		parameters.logic_extents_per_physical = 1; | ||||
| 		parameters.reserved_tracks = 0; | ||||
| 		Storage::Disk::CPM::ParameterBlock data_format; | ||||
| 		data_format.sectors_per_track = 9; | ||||
| 		data_format.tracks = 40; | ||||
| 		data_format.block_size = 1024; | ||||
| 		data_format.first_sector = 0xc1; | ||||
| 		data_format.catalogue_allocation_bitmap = 0xc000; | ||||
| 		data_format.reserved_tracks = 0; | ||||
|  | ||||
| 		Storage::Disk::CPM::GetCatalogue(target.disks.front(), parameters); | ||||
| 		std::unique_ptr<Storage::Disk::CPM::Catalogue> data_catalogue = Storage::Disk::CPM::GetCatalogue(target.disks.front(), data_format); | ||||
| 		if(data_catalogue) { | ||||
| 			InspectDataCatalogue(data_catalogue, target); | ||||
| 		} else { | ||||
| 			Storage::Disk::CPM::ParameterBlock system_format; | ||||
| 			data_format.sectors_per_track = 9; | ||||
| 			data_format.tracks = 40; | ||||
| 			data_format.block_size = 1024; | ||||
| 			data_format.first_sector = 0x41; | ||||
| 			data_format.catalogue_allocation_bitmap = 0xc000; | ||||
| 			data_format.reserved_tracks = 2; | ||||
|  | ||||
| 			std::unique_ptr<Storage::Disk::CPM::Catalogue> system_catalogue = Storage::Disk::CPM::GetCatalogue(target.disks.front(), system_format); | ||||
| 			if(system_catalogue) { | ||||
| 				InspectSystemCatalogue(data_catalogue, target); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	destination.push_back(target); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user