From 363e14a92fd2f9471af1da3ee7ca49233890d8bc Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 5 Jun 2016 08:33:01 -0400 Subject: [PATCH] Reorganised system ROMs out of the Mac-specific folder, adjusted Mac code to expect to find them organised hierarchically (as how many os.roms am I going to have?) and added readme files to explain what's missing from the Git repository. --- .gitignore | 3 +- .../Clock Signal.xcodeproj/project.pbxproj | 72 ++----------------- .../Documents/ElectronDocument.swift | 16 +++-- .../Documents/MachineDocument.swift | 9 +++ ROMImages/Electron/readme.txt | 16 +++++ ROMImages/Vic20/readme.txt | 17 +++++ 6 files changed, 57 insertions(+), 76 deletions(-) create mode 100644 ROMImages/Electron/readme.txt create mode 100644 ROMImages/Vic20/readme.txt diff --git a/.gitignore b/.gitignore index 1d4cfe47f..3eacdcc4a 100644 --- a/.gitignore +++ b/.gitignore @@ -19,8 +19,7 @@ DerivedData .DS_Store # Exclude system ROMs -OSBindings/Mac/Clock Signal/Resources/Electron/* -OSBindings/Mac/Clock Signal/Resources/Vic20/* +ROMImages/* # CocoaPods # diff --git a/OSBindings/Mac/Clock Signal.xcodeproj/project.pbxproj b/OSBindings/Mac/Clock Signal.xcodeproj/project.pbxproj index a0498bf5f..6d16df570 100644 --- a/OSBindings/Mac/Clock Signal.xcodeproj/project.pbxproj +++ b/OSBindings/Mac/Clock Signal.xcodeproj/project.pbxproj @@ -32,16 +32,6 @@ 4B73C71D1D036C030074D992 /* Vic20Document.xib in Resources */ = {isa = PBXBuildFile; fileRef = 4B73C71B1D036C030074D992 /* Vic20Document.xib */; }; 4B886FF21D03B517004291C3 /* Vic20.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 4B886FF01D03B517004291C3 /* Vic20.cpp */; }; 4B886FF51D03B61E004291C3 /* CSVic20.mm in Sources */ = {isa = PBXBuildFile; fileRef = 4B886FF41D03B61E004291C3 /* CSVic20.mm */; }; - 4B8870021D03BFEC004291C3 /* basic.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FF81D03BFEC004291C3 /* basic.bin */; }; - 4B8870031D03BFEC004291C3 /* characters-danish.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FF91D03BFEC004291C3 /* characters-danish.bin */; }; - 4B8870041D03BFEC004291C3 /* characters-english.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFA1D03BFEC004291C3 /* characters-english.bin */; }; - 4B8870051D03BFEC004291C3 /* characters-japanese.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFB1D03BFEC004291C3 /* characters-japanese.bin */; }; - 4B8870061D03BFEC004291C3 /* characters-swedish.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFC1D03BFEC004291C3 /* characters-swedish.bin */; }; - 4B8870071D03BFEC004291C3 /* kernel-danish.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFD1D03BFEC004291C3 /* kernel-danish.bin */; }; - 4B8870081D03BFEC004291C3 /* kernel-japanese.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFE1D03BFEC004291C3 /* kernel-japanese.bin */; }; - 4B8870091D03BFEC004291C3 /* kernel-ntsc.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B886FFF1D03BFEC004291C3 /* kernel-ntsc.bin */; }; - 4B88700A1D03BFEC004291C3 /* kernel-pal.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B8870001D03BFEC004291C3 /* kernel-pal.bin */; }; - 4B88700B1D03BFEC004291C3 /* kernel-swedish.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4B8870011D03BFEC004291C3 /* kernel-swedish.bin */; }; 4B92EACA1B7C112B00246143 /* TimingTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B92EAC91B7C112B00246143 /* TimingTests.swift */; }; 4BB298EE1B587D8400A49093 /* 6502_functional_test.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4BB297E01B587D8300A49093 /* 6502_functional_test.bin */; }; 4BB298EF1B587D8400A49093 /* AllSuiteA.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4BB297E11B587D8300A49093 /* AllSuiteA.bin */; }; @@ -325,9 +315,7 @@ 4BC3B7521CD1956900F86E85 /* OutputShader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 4BC3B7501CD1956900F86E85 /* OutputShader.cpp */; }; 4BC76E691C98E31700E6EF73 /* FIRFilter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 4BC76E671C98E31700E6EF73 /* FIRFilter.cpp */; }; 4BC76E6B1C98F43700E6EF73 /* Accelerate.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 4BC76E6A1C98F43700E6EF73 /* Accelerate.framework */; }; - 4BCB70B41C947DDC005B1712 /* plus1.rom in Resources */ = {isa = PBXBuildFile; fileRef = 4BCB70B31C947DDC005B1712 /* plus1.rom */; }; - 4BE5F85E1C3E1C2500C43F01 /* basic.rom in Resources */ = {isa = PBXBuildFile; fileRef = 4BE5F85C1C3E1C2500C43F01 /* basic.rom */; }; - 4BE5F85F1C3E1C2500C43F01 /* os.rom in Resources */ = {isa = PBXBuildFile; fileRef = 4BE5F85D1C3E1C2500C43F01 /* os.rom */; }; + 4BC9DF451D044FCA00F44158 /* ROMImages in Resources */ = {isa = PBXBuildFile; fileRef = 4BC9DF441D044FCA00F44158 /* ROMImages */; }; /* End PBXBuildFile section */ /* Begin PBXContainerItemProxy section */ @@ -393,16 +381,6 @@ 4B886FF11D03B517004291C3 /* Vic20.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; name = Vic20.hpp; path = "Vic-20/Vic20.hpp"; sourceTree = ""; }; 4B886FF31D03B61E004291C3 /* CSVic20.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CSVic20.h; sourceTree = ""; }; 4B886FF41D03B61E004291C3 /* CSVic20.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = CSVic20.mm; sourceTree = ""; }; - 4B886FF81D03BFEC004291C3 /* basic.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = basic.bin; sourceTree = ""; }; - 4B886FF91D03BFEC004291C3 /* characters-danish.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "characters-danish.bin"; sourceTree = ""; }; - 4B886FFA1D03BFEC004291C3 /* characters-english.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "characters-english.bin"; sourceTree = ""; }; - 4B886FFB1D03BFEC004291C3 /* characters-japanese.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "characters-japanese.bin"; sourceTree = ""; }; - 4B886FFC1D03BFEC004291C3 /* characters-swedish.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "characters-swedish.bin"; sourceTree = ""; }; - 4B886FFD1D03BFEC004291C3 /* kernel-danish.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "kernel-danish.bin"; sourceTree = ""; }; - 4B886FFE1D03BFEC004291C3 /* kernel-japanese.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "kernel-japanese.bin"; sourceTree = ""; }; - 4B886FFF1D03BFEC004291C3 /* kernel-ntsc.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "kernel-ntsc.bin"; sourceTree = ""; }; - 4B8870001D03BFEC004291C3 /* kernel-pal.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "kernel-pal.bin"; sourceTree = ""; }; - 4B8870011D03BFEC004291C3 /* kernel-swedish.bin */ = {isa = PBXFileReference; lastKnownFileType = archive.macbinary; path = "kernel-swedish.bin"; sourceTree = ""; }; 4B92EAC91B7C112B00246143 /* TimingTests.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TimingTests.swift; sourceTree = ""; }; 4BAE587D1C447B7A005B9AF0 /* KeyCodes.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = KeyCodes.h; sourceTree = ""; }; 4BB297DF1B587D8200A49093 /* Clock SignalTests-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Clock SignalTests-Bridging-Header.h"; sourceTree = ""; }; @@ -706,9 +684,7 @@ 4BC76E671C98E31700E6EF73 /* FIRFilter.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = FIRFilter.cpp; sourceTree = ""; }; 4BC76E681C98E31700E6EF73 /* FIRFilter.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = FIRFilter.hpp; sourceTree = ""; }; 4BC76E6A1C98F43700E6EF73 /* Accelerate.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Accelerate.framework; path = System/Library/Frameworks/Accelerate.framework; sourceTree = SDKROOT; }; - 4BCB70B31C947DDC005B1712 /* plus1.rom */ = {isa = PBXFileReference; lastKnownFileType = file; path = plus1.rom; sourceTree = ""; }; - 4BE5F85C1C3E1C2500C43F01 /* basic.rom */ = {isa = PBXFileReference; lastKnownFileType = file; path = basic.rom; sourceTree = ""; }; - 4BE5F85D1C3E1C2500C43F01 /* os.rom */ = {isa = PBXFileReference; lastKnownFileType = file; path = os.rom; sourceTree = ""; }; + 4BC9DF441D044FCA00F44158 /* ROMImages */ = {isa = PBXFileReference; lastKnownFileType = folder; name = ROMImages; path = ../../../../ROMImages; sourceTree = ""; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ @@ -891,23 +867,6 @@ name = "Vic-20"; sourceTree = ""; }; - 4B886FF71D03BFEC004291C3 /* Vic20 */ = { - isa = PBXGroup; - children = ( - 4B886FF81D03BFEC004291C3 /* basic.bin */, - 4B886FF91D03BFEC004291C3 /* characters-danish.bin */, - 4B886FFA1D03BFEC004291C3 /* characters-english.bin */, - 4B886FFB1D03BFEC004291C3 /* characters-japanese.bin */, - 4B886FFC1D03BFEC004291C3 /* characters-swedish.bin */, - 4B886FFD1D03BFEC004291C3 /* kernel-danish.bin */, - 4B886FFE1D03BFEC004291C3 /* kernel-japanese.bin */, - 4B886FFF1D03BFEC004291C3 /* kernel-ntsc.bin */, - 4B8870001D03BFEC004291C3 /* kernel-pal.bin */, - 4B8870011D03BFEC004291C3 /* kernel-swedish.bin */, - ); - path = Vic20; - sourceTree = ""; - }; 4BB297E41B587D8300A49093 /* Wolfgang Lorenz 6502 test suite */ = { isa = PBXGroup; children = ( @@ -1302,22 +1261,11 @@ 4BE5F85A1C3E1C2500C43F01 /* Resources */ = { isa = PBXGroup; children = ( - 4B886FF71D03BFEC004291C3 /* Vic20 */, - 4BE5F85B1C3E1C2500C43F01 /* Electron */, + 4BC9DF441D044FCA00F44158 /* ROMImages */, ); path = Resources; sourceTree = ""; }; - 4BE5F85B1C3E1C2500C43F01 /* Electron */ = { - isa = PBXGroup; - children = ( - 4BCB70B31C947DDC005B1712 /* plus1.rom */, - 4BE5F85C1C3E1C2500C43F01 /* basic.rom */, - 4BE5F85D1C3E1C2500C43F01 /* os.rom */, - ); - path = Electron; - sourceTree = ""; - }; /* End PBXGroup section */ /* Begin PBXNativeTarget section */ @@ -1427,24 +1375,12 @@ isa = PBXResourcesBuildPhase; buildActionMask = 2147483647; files = ( - 4B8870021D03BFEC004291C3 /* basic.bin in Resources */, 4B2E2D951C399D1200138695 /* ElectronDocument.xib in Resources */, - 4B88700B1D03BFEC004291C3 /* kernel-swedish.bin in Resources */, 4BB73EA91B587A5100552FC2 /* Assets.xcassets in Resources */, - 4BE5F85F1C3E1C2500C43F01 /* os.rom in Resources */, - 4BCB70B41C947DDC005B1712 /* plus1.rom in Resources */, - 4B8870071D03BFEC004291C3 /* kernel-danish.bin in Resources */, 4BB73EA71B587A5100552FC2 /* Atari2600Document.xib in Resources */, - 4B8870031D03BFEC004291C3 /* characters-danish.bin in Resources */, 4B73C71D1D036C030074D992 /* Vic20Document.xib in Resources */, - 4B8870041D03BFEC004291C3 /* characters-english.bin in Resources */, - 4B88700A1D03BFEC004291C3 /* kernel-pal.bin in Resources */, 4BB73EAC1B587A5100552FC2 /* MainMenu.xib in Resources */, - 4B8870051D03BFEC004291C3 /* characters-japanese.bin in Resources */, - 4B8870091D03BFEC004291C3 /* kernel-ntsc.bin in Resources */, - 4B8870061D03BFEC004291C3 /* characters-swedish.bin in Resources */, - 4BE5F85E1C3E1C2500C43F01 /* basic.rom in Resources */, - 4B8870081D03BFEC004291C3 /* kernel-japanese.bin in Resources */, + 4BC9DF451D044FCA00F44158 /* ROMImages in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; diff --git a/OSBindings/Mac/Clock Signal/Documents/ElectronDocument.swift b/OSBindings/Mac/Clock Signal/Documents/ElectronDocument.swift index 9f73af395..6b523d636 100644 --- a/OSBindings/Mac/Clock Signal/Documents/ElectronDocument.swift +++ b/OSBindings/Mac/Clock Signal/Documents/ElectronDocument.swift @@ -20,16 +20,20 @@ class ElectronDocument: MachineDocument { return NSSize(width: 11.0, height: 10.0) } + private func rom(name: String) -> NSData? { + return dataForResource(name, ofType: "rom", inDirectory: "ROMImages/Electron") + } + override func windowControllerDidLoadNib(aController: NSWindowController) { super.windowControllerDidLoadNib(aController) self.intendedCyclesPerSecond = 2000000 - if let osPath = NSBundle.mainBundle().pathForResource("os", ofType: "rom") { - self.electron.setOSROM(NSData(contentsOfFile: osPath)!) + if let os = rom("os") { + self.electron.setOSROM(os) } - if let basicPath = NSBundle.mainBundle().pathForResource("basic", ofType: "rom") { - self.electron.setBASICROM(NSData(contentsOfFile: basicPath)!) + if let basic = rom("basic") { + self.electron.setBASICROM(basic) } establishStoredOptions() @@ -57,8 +61,8 @@ class ElectronDocument: MachineDocument { } override func readFromData(data: NSData, ofType typeName: String) throws { - if let plus1Path = NSBundle.mainBundle().pathForResource("plus1", ofType: "rom") { - electron.setROM(NSData(contentsOfFile: plus1Path)!, slot: 12) + if let plus1ROM = rom("plus1") { + electron.setROM(plus1ROM, slot: 12) } electron.setROM(data, slot: 15) } diff --git a/OSBindings/Mac/Clock Signal/Documents/MachineDocument.swift b/OSBindings/Mac/Clock Signal/Documents/MachineDocument.swift index 3f8e8ec60..24c757c56 100644 --- a/OSBindings/Mac/Clock Signal/Documents/MachineDocument.swift +++ b/OSBindings/Mac/Clock Signal/Documents/MachineDocument.swift @@ -95,6 +95,15 @@ class MachineDocument: NSDocument, CSOpenGLViewDelegate, CSOpenGLViewResponderDe lastTime = time } + // MARK: Utilities for children + func dataForResource(name : String, ofType type: String, inDirectory directory: String) -> NSData? { + if let path = NSBundle.mainBundle().pathForResource(name, ofType: type, inDirectory: directory) { + return NSData(contentsOfFile: path) + } + + return nil + } + // MARK: CSOpenGLViewDelegate func runForNumberOfCycles(numberOfCycles: Int32) { if actionLock.tryLock() { diff --git a/ROMImages/Electron/readme.txt b/ROMImages/Electron/readme.txt new file mode 100644 index 000000000..8e81ed5e6 --- /dev/null +++ b/ROMImages/Electron/readme.txt @@ -0,0 +1,16 @@ +ROM files would ordinarily go here; the copyright status of these is uncertain so they have not been included in this repository. + +Expected files: + +basic.rom +os.rom +plus1.rom + +Likely to be desired in the future: + +adfs.rom +ADFS-E00_1.rom +ADFS-E00_2.rom +DFSE00r3.rom +ElectronExpansionRomPresAP2-v1.23.rom +os300.rom diff --git a/ROMImages/Vic20/readme.txt b/ROMImages/Vic20/readme.txt new file mode 100644 index 000000000..360af257b --- /dev/null +++ b/ROMImages/Vic20/readme.txt @@ -0,0 +1,17 @@ +ROM files would ordinarily go here; the copyright status of these is uncertain so they have not been included in this repository. + +Expected files: + +basic.bin +characters-english.bin +kernel-ntsc.rom + +Likely to be desired in the future: + +characters-danish.bin +characters-japanese.bin +characters-swedish.bin +kernel-danish.bin +kernel-japanese.bin +kernel-pal.bin +kernel-swedish.bin \ No newline at end of file